资料介绍
Table of Contents
Distributed Control System (DCS) Demo
General Description/Overview
The Distributed Control System reference design is a hardware and software platform for developing HART-enabled analog input and output modules (or nodes). DCS Modules are assembled from several existing reference designs:
- EVAL-ADICUP3029 is the processor board that implements a MODBUS slave and controls the analog input / output boards.
- EVAL-CN0414-ARDZ provides four group-isolated voltage inputs and four HART enabled current inputs.
- EVAL-CN0418-ARDZ provides four group-isolated voltage or HART-enabled current outputs
The reference design provides software connectivity using the MODBUS protocol. Modbus is a ubiquitous, open, industrial communication protocol for which there are numerous open-source and commercial software libraries and utilities. It is a serial master-slave protocol where the master uses a set of standard commands to read and write registers on the slave device, and CRC error detection ensures data integrity. Reading a slave register can give information about the state and inputs of the slave and writing registers can change the state or outputs of the slave. The mapping of Modbus registers to application-specific functions is dependent on the end application, and the DCS reference design provides convenient access to all of the functionality of the analog input and output boards.
Several options for communicating with the hardware are provided or demonstrated:
Demo Requirements
The following is a list of items needed in order to replicate this demo.
- Hardware
- EVAL-ADICUP3029
- EVAL-CN0414-ARDZ and/or EVAL-CN0418-ARDZ, up to 4 boards total, in any configuration
- EVAL-CN0416-ARDZ (not needed for direct USB connection to a single node)
- Additional EVAL-CN0416-ARDZ, ADALM-UARTJTAG, and 2×5, 100mil cable such as AMP A3AAH-1006G or:
- other RS485 host adapter
- Mirco USB to USB cable
- PC or Laptop with a USB port
- Software
- CrossCore Embedded Studio (2.8.0 or higher)
- ADuCM302x DFP (3.2.0 or higher)
- ADICUP3029 BSP (1.1.0 or higher)
- Serial Terminal Program (Required for running in CLI mode only)
- Such as Putty or Tera Term
- Python 3.6 (only required for modifying example applications)
Setting up the Hardware
Depending on the PLC/DCS Node configuration the power needs to be provided as follows:
- If the PLC/DCS Node contain at least a CN0418 board, then the power will be provided through any CN0418 board (the jumper for P17 MUST to be placed for each board).
- If the PLC/DCS Node contain only CN0414 boards, then the power can be provided through any CN0414 board.
Refer to the CN0414 and CN0418 user guides for detailed information on power requirements.
PLC / Single or multi-node DCS System Setup Configuration
Block diagrams for PLC / single-node DCS and multi-node DCS systems are shown below. These systems differ slightly in their allowable configurations:
- A Single-node system can operate with either half-duplex or full-duplex RS-485. Termination must be enabled at both ends of the RS-485 line(s).
- Modbus address conflict is not a concern in a single-node system (but the address must be known to the host.)
- A Multi-node system can only operate in half-duplex mode.
- In a Multi-node system, termination must be enabled at the ends of the RS-485 line, which is most often the host RS485 adapter and most distant node.
- Each node in a multi-node system must be set to a different address.
PLC / Single-node DCS System block diagram
DCS System block diagram
RS485 Adapter Configuration
An ADALM-UARTJTAG board and a spare CN0416 can function as a convenient USB Virtual COM port to RS-485 adapter. Any RS485 adapter should work, if another is available. Isolated / Non-Isolated depends on the application and difference in ground potential between the host and nodes. Full-duplex operation is only supported in the PLC/single-node DCS configuration, as both TX and RX signals are driven continuously. Both single-node and multi-node configurations can use half-duplex.
ADALM-UARTJTAG Setup |
---|
The CP2103 device must be programmed as follows to control the DE signal on the CN0416. Configure Silicon Labs Xpress Configurator as follows to program the device:
IO2 configuration | Mode: Push-Pull, Alternate Function: RS-485, Active High |
Once the CP2103 is programmed, unplug from the host computer and connect P1 on the ADALM-UARTJTAG to P11 on the CN0416 with a 2×5-socket, 100mil cable such as AMP A3AAH-1006G. Be sure to connect with proper polarity - pin 1 on the ADALM-UARTJTAG must correspond to pin 1 on the CN0416.
CN0416 Setup | ||||
---|---|---|---|---|
Isolated Full Duplex | Isolated Half Duplex | Non-Isolated Full Duplex | Non-isolated Half Duplex | |
S1 position | NA | NA | NA | NA |
S2 position | 2 | 1 | 3 | 4 |
S4 position | NA | NA | 2 | 1 |
S5 position | 2 | 1 | NA | NA |
S6 position | NA | NA | 2 | 2 |
S7 position | 2 | 2 | NA | NA |
Node Configuration
Configuration for each node is similar, noting that each node must be set to a different address (via S1 on the CN0416) and the most distant node must have its termination enabled (via S6 or S7 on CN0416.)
CN0416 Setup |
---|
(Full-duplex only valid in a single-node system.)
Isolated Full Duplex | Isolated Half Duplex | Non-Isolated Full Duplex | Non-isolated Half Duplex | |
---|---|---|---|---|
S1 position | Any position but different from node to node | |||
S2 position | 2 | 1 | 3 | 4 |
S4 position | NA | NA | 2 | 1 |
S5 position | 2 | 1 | NA | NA |
S6 position | NA | NA | 2 | 2 |
S7 position | 2 | 2 | NA | NA |
CN0414 Setup (if available) | ||||
P1 position | Any position from MULTI configuration |
|||
P2 position | ||||
P10 position | Any position to result a different EEPROM address from board to board |
|||
P11 position | ||||
P12 position | ||||
JP1 position | MULTI configuration position | |||
CN0418 Setup (if available) | ||||
P10 position | Any position from MULTI configuration |
|||
P9 position | ||||
JP2 position | Any position to result a different EEPROM address from board to board |
|||
JP3 position | ||||
JP4 position | ||||
JP1 position | MULTI configuration position | |||
P17 position | Jumper should be placed to power the whole system | |||
EVAL-ADICUP3029 | ||||
S2 position | ARDUINO position | |||
S5 position | WALL/USB position |
Direct USB connection
Direct USB Configuration
The CLI program does not need the EVAL-CN0416-ARDZ board and is not affected by it's presence either. Furthermore, the PLC/ single-node DCS configuration can also operate with a direct connection, useful for testing out individual nodes quickly.
EVAL-ADICUP3029 | |
---|---|
S2 position | USB position |
S5 position | WALL/USB position |
MODBUS Implementation
There are four types of standard registers in the MODBUS slave:
Coil/Register Number | Data addresses | Types | Names |
---|---|---|---|
1 - 9999 | 0 to 270E | Read-Write | Discreet Output Coils |
10001 - 19999 | 0 to 270E | Read-Only | Discreet Input Contacts |
30001 - 39999 | 0 to 270E | Read-Only | Analog Input Registers |
40001 - 49999 | 0 to 270E | Read-Write | Output Holding Registers |
Each of these registers have a 16-bit address and a 16-bit value.
The Discreet Output Coils are registers that control a single output wire that has a binary value (high or low). Reading this register returns the output value of the bit and writing to it will update the coil with either low value, for writing 0, or high value, for writing anything else. The Discreet Input Contacts are registers that represent the value of a single input logic wire. The register can be only read and it is 0 if the wire is logic low and 0XFFFF if the wire is logic high. The DCS reference design does not have any functions that would map to Discreet Output Coils or Discreet Input Contacts. The Analog Input Registers represent an analog value, usually from an analog wire. This register can be only read and returns a 16-bit value. The Output Holding Registers are registers that control an analog output or a state of the slave. Reading this register returns the state of a process or an output and writing to it may change them or start a process.
Each register can be accessed using a function code:
Function code | Action | Table name |
---|---|---|
1 (0x01) | Read | Discreet Output Coils |
5 (0x05) | Write Single | Discreet Output Coils |
15 (0x0F) | Write Multiple | Discreet Output Coils |
2 (0x02) | Read | Discreet Input Contacts |
4 (0x04) | Read | Analog Input Registers |
3 (0x03) | Read | Output Holding Registers |
6 (0x06) | Write Single | Output Holding Registers |
16 (0x10) | Write Multiple | Output Holding Registers |
DCS reference design MODBUS Register Map
Because the DCS reference design may contain any combination of up to four input or output boards, as a MODBUS slave, it contains two type of MODBUS registers: common and board specific.
The common registers are 5 read-only registers and 2 read-write registers. In standard MODBUS terminology that translates to 5 analog input registers and 2 holding registers:
Name | Address | Type | Description |
---|---|---|---|
Detected boards | 0x0000 | Analog Input Register | Number of input and/or output boards present in the system. |
First board data | 0x0001 | Analog Input Register | First board type (bit 0), First board CS address (bits 1,2) |
Second board data | 0x0002 | Analog Input Register | Second board type (bit 0), Second board CS address (bits 1,2) |
Third board data | 0x0003 | Analog Input Register | Third board type (bit 0), Third board CS address (bits 1,2) |
Fourth board data | 0x0004 | Analog Input Register | Fourth board type (bit 0), Fourth board CS address (bits 1,2) |
Update rate MSW | 0x00FE | Output Holding Register | Most significant word of the update rate. |
Update rate LSW | 0x00FF | Output Holding Register | Least significant word of the update rate. |
The board type bit is “0” for CN0414 and “1” for CN0418.
The update rate is stored as:
Update rate MSW = ((Actual update rate * 10000) & 0xFFFF0000) >> 16; Update rate LSW = ((Actual update rate * 10000) & 0x0000FFFF) >> 0;
So the equation used to retrieve the update rate is:
Or in code form:
Actual update rate = (((Update rate MSW << 16) & 0xFFFF0000) | Update rate LSW) / 10000;
The register map is configured dynamically after power-up. Adding a board to the system adds a number of board specific registers: 50 analog input registers and 7 output holding registers for each EVAL-CN0414-ARDZ, and 30 analog input registers and 10 output holding registers for each EVAL-CN0418-ARDZ.
As stated before, adding an EVAL-CN0414-ARDZ adds 57 registers to the device: 50 analog input registers and 7 output holding registers. The analog input registers are: 16 for ADC input values, 4 for ADC input open wire detection flags and 50 for HART receive buffer. The output holding registers are: 1 for ADC output coding, 1 for ADC filter options, 1 for ADC postfilter options, 1 for ADC output data rate options, 1 for ADC open wire detection enable, 1 for HART command zero and 1 for HART channel select. The output holding registers are: 16 for the channel registers, 4 for Open Wire Detection and 30 for the HART input buffer. Adding an EVAL-CN0418-ARDZ adds 40 registers: 30 analog input registers and 10 output holding registers. There are 30 HART input registers as analog input registers. The output holding registers are: 4 for channel ranges (one for each channel), 4 for the channels output (one for each channel), 1 for the HART active channel and 1 for the HART command zero.
Note that being a dynamic system the registers presented below do not have an unique address, but have an address offset that can be used to calculate their address. The function is:
Address = (ADC_CS_address << 12) + (MODBUS_slave_address << 8) + Address_offset;
Register map for the EVAL-CN0414-ARDZ:
Name | Address Offset | Type | Description |
---|---|---|---|
Channel 1 MSW | 0x05 | Analog Input Register | Most significant word of the first ADC channel. |
Channel 1 LSW | 0x06 | Analog Input Register | Least significant word of the first ADC channel. |
Channel 2 MSW | 0x07 | Analog Input Register | Most significant word of the second ADC channel. |
Channel 2 LSW | 0x08 | Analog Input Register | Least significant word of the second ADC channel. |
… | … | … | … |
Channel 8 MSW | 0x13 | Analog Input Register | Most significant word of the eighth ADC channel. |
Channel 8 LSW | 0x14 | Analog Input Register | Least significant word of the eighth ADC channel. |
Channel 1 OWD | 0x15 | Analog Input Register | Open wire detection flag of the first voltage channel. |
Channel 2 OWD | 0x16 | Analog Input Register | Open wire detection flag of the second voltage channel. |
Channel 3 OWD | 0x17 | Analog Input Register | Open wire detection flag of the third voltage channel. |
Channel 4 OWD | 0x18 | Analog Input Register | Open wire detection flag of the fourth voltage channel. |
HART IN 1 | 0x19 | Analog Input Register | First word of the HART input buffer. |
HART IN 2 | 0x1A | Analog Input Register | Second word of the HART input buffer. |
… | … | … | … |
HART IN 30 | 0x36 | Analog Input Register | 50th word of the HART input buffer. |
ADC Output Code | 0x00 | Output Holding Register | Set the output coding for the ADC: 0 - bipolar coding (default); 1 - unipolar coding. |
ADC Filter | 0x01 | Output Holding Register | Set the input filter for the ADC: 0 - s5+s1 (default); 1 - s3. |
ADC Postfilter | 0x02 | Output Holding Register | Set the input postfilter for the ADC: 0 - 27 SPS, 47 dB rejection, 36.7 ms settling; 1 - 25 SPS, 62 dB rejection, 40 ms settling; 2 - 20 SPS, 86 dB rejection, 50 ms settling; 3 - 16.67 SPS, 92 dB rejection, 60 ms settling; 4 - disable postfilter (default). |
ADC ODR | 0x03 | Output Holding Register | Set the output data rate for the ADC: [0-5] - 31250 SPS (default); 6 - 15625 SPS; 7 - 10417 SPS; 8 - 5208 SPS; 9 - 2597 SPS; 10 - 1007 SPS; 11 - 503.8 SPS; 12 - 381 SPS; 13 - 200.3 SPS; 14 - 100.5 SPS; 15 - 59.52 SPS; 16 - 49.68 SPS; 17 - 20.01 SPS; 18 - 16.63 SPS; 19 - 10 SPS; 20 - 5 SPS; 21 - 2.5 SPS; 22 - 1.25 SPS; |
ADC OWD EN | 0x04 | Output Holding Register | Enable/disable open wire detection for the ADC: 0 - disable OWD (default); 1 - enable OWD. |
HART cmd 0 | 0x05 | Output Holding Register | Writing “1” to this register sends HART command 0 then the register resets to “0”. |
HART CH select | 0x06 | Output Holding Register | Select enable a current channel for HART communication: 0 - Channel 1 (default); 1 - Channel 2; 2 - Channel 3; 3 - Channel 4. |
Register map for the EVAL-CN0418-ARDZ:
Name | Address Offset | Type | Description |
---|---|---|---|
HART IN 1 | 0x05 | Analog Input Register | First word of the HART input buffer. |
HART IN 2 | 0x06 | Analog Input Register | Second word of the HART input buffer. |
… | … | … | … |
HART IN 30 | 0x22 | Analog Input Register | 50th word of the HART input buffer. |
Channel 1 range | 0x00 | Output Holding Register | Output range for the first DAC channel: 0 - 0V to 5V; 1 - 0V to 10V; 2 - -5V to 5V; 3 - -10V to 10V; 4 - 4ma to 20ma; 5 - 0ma to 20ma; 6 - 0ma to 24ma. |
Channel 2 range | 0x01 | Output Holding Register | Output range for the second DAC channel: 0 - 0V to 5V; 1 - 0V to 10V; 2 - -5V to 5V; 3 - -10V to 10V; 4 - 4ma to 20ma; 5 - 0ma to 20ma; 6 - 0ma to 24ma. |
Channel 3 range | 0x02 | Output Holding Register | Output range for the third DAC channel: 0 - 0V to 5V; 1 - 0V to 10V; 2 - -5V to 5V; 3 - -10V to 10V; 4 - 4ma to 20ma; 5 - 0ma to 20ma; 6 - 0ma to 24ma. |
Channel 4 range | 0x03 | Output Holding Register | Output range for the fourth DAC channel: 0 - 0V to 5V; 1 - 0V to 10V; 2 - -5V to 5V; 3 - -10V to 10V; 4 - 4ma to 20ma; 5 - 0ma to 20ma; 6 - 0ma to 24ma. |
Channel 1 | 0x04 | Output Holding Register | Output code of the first DAC channel. |
Channel 2 | 0x05 | Output Holding Register | Output code of the second DAC channel. |
Channel 3 | 0x06 | Output Holding Register | Output code of the third DAC channel. |
Channel 4 | 0x07 | Output Holding Register | Output code of the fourth DAC channel. |
HART cmd 0 | 0x08 | Output Holding Register | Writing “1” to this register sends HART command 0 then the register resets to “0”. |
HART CH select | 0x09 | Output Holding Register | Select enable a current channel for HART communication: 0 - Channel A (default); 1 - Channel B; 2 - Channel C; 3 - Channel D. |
Configuring the Software
The software can be set up to work in CLI debug mode or in MODBUS mode. To set this make sure the relevant define in the config.h file is uncommented and the other one is commented:
//#define CLI_INTEFACE //#define MODBUS_INTERFACE
Communicating with the DCS reference design
There are two interfaces available for this application: a Command Line Interface (CLI) used mainly for debugging a single PLC node and a MODBUS interface used for PLC/DCS operation for single and multiple nodes.
The CLI is implemented through UART and must be connected to a computer via USB cable. A serial terminal program must run on the host PC to display data and control the application.
The MODBUS is connected through the EVAL-CN0416-ARDZ UART to RS485 adapter and must communicate with a MODBUS master on the RS485 line.
Command Line Interface
Serial Terminal Output
A serial terminal is an application that runs on a PC or laptop that is used to display data and interact with a connected device (including many of the Circuits from the Lab reference designs). The device's UART peripheral is most often connected to a UART to USB interface IC, which appears as a traditional COM port on the host PC/ laptop. (Traditionally, the device's UART port would have been connected to an RS-232 line driver / receiver and connected to the PC via a 9-pin or 25-pin serial port.) There are many open-source applications, and while there are many choices, typically we use one of the following:
Before continuing, please make sure you download and install one of the above programs.
There are several parameters on all serial terminal programs that must be setup properly in order for the PC and the connected device to communicate. Below are the common settings that must match on both the PC side and the connected UART device.
- COM Port - This is the physical connection made to your PC or Laptop, typically made through a USB cable but can be any serial communications cable. You can determine the COM port assigned to your device by visiting the device manager on your computer. Another method for identifying which COM port is associated with a USB-based device is to look at which COM ports are present before plugging in your device, then plug in your device, and look for a new COM port.
- Baud Rate - This is the speed at which data is being transferred from the connected device to your PC. These parameters must be the same on both devices or data will be corrupted. The default setting for most of the reference designs in 115200.
- Data Bits - The number of data bits per transfer. Typically UART transmits ASCII codes back to the serial port so by default this is almost always set to 8-Bits.
- Stop Bits - The number of “stop” conditions per transmission. This usually set to 1, but can be set to 2 for redundancy.
- Parity - Is a way to check for errors during the UART transmission. Unless otherwise specified, set parity to “none”.
- Flow Control - Is a way to ensure that data lose between fast and slow devices on the same UART bus are not lost during transmission. This is typically not implemented in a simple system, and unless otherwise specified, set to “none”.
In many instances there are other options that each of the different serial terminal applications provide, such as local line echo or local line editing, and features like this can be turned on or off depending on your preferences. This setup guide will not go over all the options of each tool, but just the minor features that will make it easier to read back data from the connected devices.
Example setup using Putty
- Plug in your connected device using a USB cable or other serial cable.
- Wait for the device driver of the connected device to install on your PC or Laptop.
- Open up your serial terminal program (Putty for this example)
- Click on the open button, and as long as your connected device and serial terminal program are setup the same, than you should see data displaying.
Available Commands
Typing help or h after initial calibration sequence will display the list of commands and their short versions. The CLI mode has a board command menu which is only used to select the board. Each board present in the system has it's own command set based on the type.
Bellow is the short command list for the board menu:
Command | Description |
---|---|
h | Display available commands. |
bs | Set the active board. <board_no> = de ID of the board assigned by the program. It its displayed at the start of the program. Calling this command without an argument displays available boards again. |
The specific commands for each of the types of boards is described in they respective wiki pages:
Modbus Interface
The Modbus protocol is not human-readable; as such, a Modbus master program is required to interact with the design. QModMaster is a free and open-source implementation of a Modbus master GUI application. This program is useful for board bringup and debug, and during application development. QModMaster is avalable at QModMaster on SourceForge
QModMaster is used to demonstrate several basic register operations below.
Obtaining the Source Code
We recommend not opening the project directly, but rather import it into CrossCore Embedded Studios and make a local copy in your workspace.
The source code and include files of the ADuCM3029_demo_cn0435 can be found here:
How to use the Tools
The official tool we promote for use with the EVAL-ADICUP3029 is CrossCore Embedded Studio. For more information on downloading the tools and a quick start guide on how to use the tool basics, please check out the Tools Overview page.
Importing
For more detailed instructions on importing this application/demo example into the CrossCore Embedded Studios tools, please view our How to import existing projects into your workspace section.
Debugging
For more detailed instructions on importing this application/demo example into the CrossCore Embedded Studios tools, please view our How to configure the debug session section.
Project Structure
The application controls a dynamic system that can be physically different every time it is run. to do this it has two parts:
- The system initialization.
- The system main process.
After getting parameters of the system supplied by the user in code the program initializes the software modules common to all the boards: I2C, UART, SPI, microcontroller power, software UART and the AD5700 HART modem. If the MODBUS interface is used, the update timer for the input boards is also initialized in this stage as a common module. If, by comparison, the CLI is used, each input board present initializes its own version of the update timer driver.
After these initializations the system runs a board discovery routine. By using the presence of I2C EEPROM memory and testing the SPI configuration, all boards in the system are discovered and labeled as either CN0414 or CN0418. If the MODBUS interface is used, the system also scans for its MODBUS slave address and maps and initializes MODBUS registers.
After board discovery, if the CLI is used, no board is set as active and the system manager loads the main menu process. If the MODBUS is used, the system activates the first board it discovers.
CLI Process
If the CLI is used, no board is active after the initialization and the system stands by to receive commands. If the user sets one of the boards to be active, the program loads the commands and process specific to that board and starts sunning them until the application is stopped or the “exit” command is called.
MODBUS Interface Process
If the MODBUS interface is used the first board discovered is the active board. If it is a CN0414 the program runs its process until all channels are updated. If it is a CN0418 the program runs its process only once. After this the system deactivates the board and activates the next board discovered until all the boards have been active and updated. The system than cycles back from the beginning.
Meanwhile the system scans the MODBUS channel for commands and if one is found that is addressed to this node it executes it and sends back a response.
Board Specific Processes
The process and commands for each type of boards is described in the appropriate application page:
Example Applications and Utilities
User DCS programs running on the host will be highly application-specific, and written in any number of languages. This section presents several example applications and utilities written in Python that perform basic functions such as reading and writing analog voltages, detecting the configuration of a node, and changing the data rate of an analog input channel.
Utility functions in Python
The following utility functions are demonstrated using the single-node configuration described above. It may be connected to the host either directly via USB (no RS485 interface) or over a USB to RS485 bridge. Minimalmodbus is an open-source (Apache license) Modbus RTU and Modbus ASCII implementation for Python, and is used in these examples. Similar libraries exist for other languages.
Read common analog input registers basic example
For example, consider an instrument (slave) with Modbus RTU and address number 1 to which we are to communicate via a serial port with the name COM12
. The instrument stores the actual configuration in registers 0 to 4. To read data from the instrument:
- read_common_analog_input_registers.py
"""Read common analog input registers to determine PLC/DCS configuration.""" import minimalmodbus # declare an instrument object with port name, slave address as input arguments INSTRUMENT = minimalmodbus.Instrument('COM12', 1) # read 5 registers starting from address 0 by using function code 4 COMMON_ANALOG_INPUT_REGISTERS = INSTRUMENT.read_registers( registeraddress=0, numberOfRegisters=5, functioncode=4) # result a list with 5 elements in decimal format print(COMMON_ANALOG_INPUT_REGISTERS)
[4, 1, 3, 4, 6]
In this example, after we run the above piece of code it results that we have 4 boards connected. Two of this boards are EVAL-CN0414-ARDZ and other two are EVAL-CN0418-ARDZ. The EVAL-CN0414-ARDZ boards have address 0b10 and 0b11 while EVAL-CN0418-ARDZ boards have address 0b00 and 0b01.
Read analog input registers basic example
Next, if we want to read all analog input channels from one EVAL-CN0414-ARDZ we can use the following:
- read_adc_analog_input_registers.py
"""Read analog input registers to determine ADC channels code.""" import minimalmodbus # declare an instrument object with port name, slave address as input arguments INSTRUMENT = minimalmodbus.Instrument('COM12', 1) # read 16 registers starting from address 12549 by using function code 4 ADC_CHANNELS_CODES = INSTRUMENT.read_registers( registeraddress=12549, numberOfRegisters=16, functioncode=4) # result a list with 16 elements in decimal format print(ADC_CHANNELS_CODES)
[127, 65158, 127, 65514, 127, 65194, 127, 64995, 127, 65285, 127, 65244, 127, 65292, 127, 65278]
In this example, after we run the above piece of code it results a list of 16 elements in decimal format. First 8 values corespond to voltage channels and last to current channels.
Read and write one output holding register for EVAL-CN0414-ARDZ example
Next, if we want to change the output code of one EVAL-CN0414-ARDZ ADC to be unipolar instead of bipolar we can use the following:
- set_adc_output_code.py
"""Read and write one output holding register to change ADC output code.""" import minimalmodbus # declare an instrument object with port name, slave address as input arguments INSTRUMENT = minimalmodbus.Instrument('COM12', 1) # read a single register from address 12544 by using function code 3 INITIAL_ADC_OUTPUT_CODE = INSTRUMENT.read_register( registeraddress=12544, functioncode=3) # result an integer print(INITIAL_ADC_OUTPUT_CODE) # wrie a single register from address 12544 by using function code 6 INSTRUMENT.write_register(registeraddress=12544, value=1, functioncode=6) # read a single register from address 12544 by using function code 3 FINAL_ADC_OUTPUT_CODE = INSTRUMENT.read_register( registeraddress=12544, functioncode=3) # result an integer print(FINAL_ADC_OUTPUT_CODE)
0 1
In this example, after we run the above piece of code it results an integer which coresponds to ADC coding format. The default value 0, indicate that the ADC is set to bipolar coding format, while a value of 1 will indicate an unipolar coding format.
Read and write one output holding register for EVAL-CN0418-ARDZ example
Next, if we want to change the output code of one EVAL-CN0418-ARDZ DAC channel we can use the following:
- set_dac_output_voltage.py
"""Read and write one output holding register to change DAC channel voltage.""" import minimalmodbus # declare an instrument object with port name, slave address as input arguments INSTRUMENT = minimalmodbus.Instrument('COM12', 1) # read a single register from address 4356 by using function code 3 INITIAL_DAC_CHANNEL_1_CODE = INSTRUMENT.read_register( registeraddress=4356, functioncode=3) # result an integer print(INITIAL_DAC_CHANNEL_1_CODE) # wrie a single register from address 4356 by using function code 6 INSTRUMENT.write_register(registeraddress=4356, value=65535, functioncode=6) # read a single register from address 4356 by using function code 3 FINAL_DAC_CHANNEL_1_CODE = INSTRUMENT.read_register( registeraddress=4356, functioncode=3) # result an integer print(FINAL_DAC_CHANNEL_1_CODE)
0 65535
In this example, after we run the above piece of code it results an integer which coresponds to DAC channel 1 output code. Depending on channel configuration this output code will corespond to a voltage or a current value. In this example the DAC channel output code is by default 0V because the default channel range is set to 0V to 5V. The 65535 value will corespond in this case to a 5V output.
Detect system configuration example
Next, if we want to determine the system configuration we can run the following script from the attached archive.
For a PLC configuration the script output will look similarly like this:
Welcome! Use 'CTRL+C' to go back from the current menu or exit! Available devices: 1 -> Silicon Labs CP210x USB to UART Bridge (COM12) 2 -> Intel(R) Active Management Technology - SOL (COM3) Enter detected device index, or press ENTER to use COM12: No boards at MODBUS address: 1 No communication with the instrument (no answer) Boards found at MODBUS address: 2 Address Name Value ------------- ----------------- ------- 0000 (0x0000) Detected boards 2 0001 (0x0001) First board data 4 0002 (0x0002) Second board data 6 0003 (0x0003) Third board data 65535 0004 (0x0004) Fourth board data 65535 Analog input board at address: 10 Analog input board at address: 11 No boards at MODBUS address: 3 No communication with the instrument (no answer) No boards at MODBUS address: 4 No communication with the instrument (no answer) No boards at MODBUS address: 5 No communication with the instrument (no answer) No boards at MODBUS address: 6 No communication with the instrument (no answer) No boards at MODBUS address: 7 No communication with the instrument (no answer) No boards at MODBUS address: 8 No communication with the instrument (no answer) No boards at MODBUS address: 9 No communication with the instrument (no answer) No boards at MODBUS address: 10 No communication with the instrument (no answer) No boards at MODBUS address: 11 No communication with the instrument (no answer) No boards at MODBUS address: 12 No communication with the instrument (no answer) No boards at MODBUS address: 13 No communication with the instrument (no answer) No boards at MODBUS address: 14 No communication with the instrument (no answer) No boards at MODBUS address: 15 No communication with the instrument (no answer) No boards at MODBUS address: 16 No communication with the instrument (no answer)
For a DCS configuration the script output will look similarly like this:
Welcome! Use 'CTRL+C' to go back from the current menu or exit! Available devices: 1 -> Silicon Labs CP210x USB to UART Bridge (COM12) 2 -> Intel(R) Active Management Technology - SOL (COM3) Enter detected device index, or press ENTER to use COM12: Boards found at MODBUS address: 1 Address Name Value ------------- ----------------- ------- 0000 (0x0000) Detected boards 2 0001 (0x0001) First board data 1 0002 (0x0002) Second board data 3 0003 (0x0003) Third board data 65535 0004 (0x0004) Fourth board data 65535 Analog output board at address: 00 Analog output board at address: 01 Boards found at MODBUS address: 2 Address Name Value ------------- ----------------- ------- 0000 (0x0000) Detected boards 2 0001 (0x0001) First board data 4 0002 (0x0002) Second board data 6 0003 (0x0003) Third board data 65535 0004 (0x0004) Fourth board data 65535 Analog input board at address: 10 Analog input board at address: 11 No boards at MODBUS address: 3 No communication with the instrument (no answer) No boards at MODBUS address: 4 No communication with the instrument (no answer) No boards at MODBUS address: 5 No communication with the instrument (no answer) No boards at MODBUS address: 6 No communication with the instrument (no answer) No boards at MODBUS address: 7 No communication with the instrument (no answer) No boards at MODBUS address: 8 No communication with the instrument (no answer) No boards at MODBUS address: 9 No communication with the instrument (no answer) No boards at MODBUS address: 10 No communication with the instrument (no answer) No boards at MODBUS address: 11 No communication with the instrument (no answer) No boards at MODBUS address: 12 No communication with the instrument (no answer) No boards at MODBUS address: 13 No communication with the instrument (no answer) No boards at MODBUS address: 14 No communication with the instrument (no answer) No boards at MODBUS address: 15 No communication with the instrument (no answer) No boards at MODBUS address: 16 No communication with the instrument (no answer)
Change or check the system registers example
Next, if we want to check or change the system registers we can run the following script from the attached archive.
Depending on the system configuration, one or more DCS nodes will be detected. After the user selects a valid DCS node, a menu will appear which contain all available system options. Now, depending on the node configuration, not all option will be valid, even if they are shown. For example, if a DCS node doesn't contain CN0414 analog input board(s), any option which refers to CN0414 will do nothing.
Welcome! Use 'CTRL+C' to go back from the current menu or exit! Available devices: 1 -> Silicon Labs CP210x USB to UART Bridge (COM12) 2 -> Intel(R) Active Management Technology - SOL (COM3) Enter detected device index, or press ENTER to use COM12: Enter MODBUS timeout (0.05[s] to inf), or press ENTER to use 0.1[s] timeout: Boards found at MODBUS address: 1 Address Name Value ------------- ----------------- ------- 0000 (0x0000) Detected boards 2 0001 (0x0001) First board data 1 0002 (0x0002) Second board data 3 0003 (0x0003) Third board data 65535 0004 (0x0004) Fourth board data 65535 analog output board at address: 00 analog output board at address: 01 Boards found at MODBUS address: 2 Address Name Value ------------- ----------------- ------- 0000 (0x0000) Detected boards 2 0001 (0x0001) First board data 4 0002 (0x0002) Second board data 6 0003 (0x0003) Third board data 65535 0004 (0x0004) Fourth board data 65535 analog input board at address: 10 analog input board at address: 11 No boards at MODBUS address: 3 No communication with the instrument (no answer) No boards at MODBUS address: 4 No communication with the instrument (no answer) No boards at MODBUS address: 5 No communication with the instrument (no answer) No boards at MODBUS address: 6 No communication with the instrument (no answer) No boards at MODBUS address: 7 No communication with the instrument (no answer) No boards at MODBUS address: 8 No communication with the instrument (no answer) No boards at MODBUS address: 9 No communication with the instrument (no answer) No boards at MODBUS address: 10 No communication with the instrument (no answer) No boards at MODBUS address: 11 No communication with the instrument (no answer) No boards at MODBUS address: 12 No communication with the instrument (no answer) No boards at MODBUS address: 13 No communication with the instrument (no answer) No boards at MODBUS address: 14 No communication with the instrument (no answer) No boards at MODBUS address: 15 No communication with the instrument (no answer) No boards at MODBUS address: 16 No communication with the instrument (no answer) Enter MODBUS address from this list [1, 2], or press ENTER to use MODBUS address 1: Enter commands delay (0[s] to inf), or press ENTER to use 0.1[s] delay: Test options: 1 - Read common analog input registers. 2 - Read common output holding registers. 3 - Read analog input registers. 4 - Read output holding registers. 5 - Write output holding register. q - Quit. Enter test option:
Example Applications in Python
The following section presents several example top-level DCS applications. Like the utilities, these are based on Minimalmodbus.
Simple DCS control
This application provides a simple way to control a DCS system and also to detect HART devices by using the HART protocol.
The HART protocol is proprietary, customers implementing a full HART stack should refer to https://fieldcommgroup.org This reference design provides a basic implementation of “command zero” that can be used to verify connectivity with HART instruments. CN0267 is a Complete 4 mA to 20 mA Loop Powered Field Instrument with HART Interface that can be used to test the DCS HART functionality. This application allows to:
- detect sistem configuration;
- configure and read ADC channels;
- configure and write DAC channels;
- configure HART modems and send HART command zero.
Welcome! Use 'CTRL+C' to go back from the current menu or exit! Available devices: 1 -> Silicon Labs CP210x USB to UART Bridge (COM12) 2 -> Intel(R) Active Management Technology - SOL (COM3) Enter detected device index, or press ENTER to use COM12: Enter MODBUS timeout (0.05[s] to inf), or press ENTER to use 0.1[s] timeout: Boards found at MODBUS address: 1 Address Name Value ------------- ----------------- ------- 0000 (0x0000) Detected boards 2 0001 (0x0001) First board data 1 0002 (0x0002) Second board data 3 0003 (0x0003) Third board data 65535 0004 (0x0004) Fourth board data 65535 analog output board at address: 00 analog output board at address: 01 Boards found at MODBUS address: 2 Address Name Value ------------- ----------------- ------- 0000 (0x0000) Detected boards 2 0001 (0x0001) First board data 4 0002 (0x0002) Second board data 6 0003 (0x0003) Third board data 65535 0004 (0x0004) Fourth board data 65535 analog input board at address: 10 analog input board at address: 11 No boards at MODBUS address: 3 No communication with the instrument (no answer) No boards at MODBUS address: 4 No communication with the instrument (no answer) No boards at MODBUS address: 5 No communication with the instrument (no answer) No boards at MODBUS address: 6 No communication with the instrument (no answer) No boards at MODBUS address: 7 No communication with the instrument (no answer) No boards at MODBUS address: 8 No communication with the instrument (no answer) No boards at MODBUS address: 9 No communication with the instrument (no answer) No boards at MODBUS address: 10 No communication with the instrument (no answer) No boards at MODBUS address: 11 No communication with the instrument (no answer) No boards at MODBUS address: 12 No communication with the instrument (no answer) No boards at MODBUS address: 13 No communication with the instrument (no answer) No boards at MODBUS address: 14 No communication with the instrument (no answer) No boards at MODBUS address: 15 No communication with the instrument (no answer) No boards at MODBUS address: 16 No communication with the instrument (no answer) Enter MODBUS address from this list [1, 2], or press ENTER to use MODBUS address 1: Enter commands delay (0[s] to inf), or press ENTER to use 0.1[s] delay: Use CTRL+C to end a process or switch between nodes. CN0414 CN0418 CN0435 ------------------------------------- ---------------------------- ---------------------------------------- 1 - Read device voltage channel e - Set DAC channel 1 output o - Read common analog input registers 2 - Read device current channel f - Set DAC channel 2 output p - Read common output holding registers 3 - Read board voltage channels g - Set DAC channel 3 output r - Read analog input registers 4 - Read board current channels h - Set DAC channel 4 output s - Read output holding registers 5 - Read instrument voltage channels i - Set DAC channel 1 range t - Detect system configuration 6 - Read instrument current channels j - Set DAC channel 2 range 7 - Set ADC output code k - Set DAC channel 3 range 8 - Set ADC filter l - Set DAC channel 4 range 9 - Set ADC postfilter m - Send HART command zero a - Set ADC output data rate n - Select HART channel b - Set ADC open wire detection state c - Send HART command zero d - Select HART channel q - Quit Enter Option:
End of Document
- CN0428用户指南
- CN0429用户指南
- Cn0411用户指南
- CN0425用户指南
- CN0415用户指南
- CN0419用户指南
- CN0416-用户指南Wiki
- CN0418用户指南
- CN0435设计文件
- CN0507用户指南
- CN0537用户指南
- CN0506用户指南
- ADA4355 wiki用户指南
- CN0549用户指南
- CN0435 Design Files
- CD100M满杯检测方案的安装指南 240次阅读
- Air780EP模块AT开发-HTTP应用指南 319次阅读
- 电工必备接线指南:轻松掌握各种电路接线技巧 805次阅读
- 滤波器设计指南 2096次阅读
- 如何在Ubuntu 20.04安装Gitea 1483次阅读
- 为什么电子指南针能指示方向 1629次阅读
- 使用含快速开关SiC器件的RC缓冲电路实用解决方案和指南 2531次阅读
- Command Line Tools for HarmonyOS最新版本简介 2713次阅读
- PCB设计之五个EMI设计指南 3397次阅读
- firefly AIO-3288J主板使用指南 1510次阅读
- 怎么搭建zedboard的编译环境? 1753次阅读
- 企业内部分机如何通过FreePBX,VOS和鼎信通达网关实现落地服务 1.2w次阅读
- iPhone自带的指南针的妙用 7562次阅读
- 基于CN3705和LM2596的锂电池充放电系统 8542次阅读
- 长虹CN-7机芯彩电场扫描电路分析 1w次阅读
下载排行
本周
- 1电子电路原理第七版PDF电子教材免费下载
- 0.00 MB | 1491次下载 | 免费
- 2单片机典型实例介绍
- 18.19 MB | 95次下载 | 1 积分
- 3S7-200PLC编程实例详细资料
- 1.17 MB | 27次下载 | 1 积分
- 4笔记本电脑主板的元件识别和讲解说明
- 4.28 MB | 18次下载 | 4 积分
- 5开关电源原理及各功能电路详解
- 0.38 MB | 11次下载 | 免费
- 6100W短波放大电路图
- 0.05 MB | 4次下载 | 3 积分
- 7基于单片机和 SG3525的程控开关电源设计
- 0.23 MB | 4次下载 | 免费
- 8基于AT89C2051/4051单片机编程器的实验
- 0.11 MB | 4次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 2PADS 9.0 2009最新版 -下载
- 0.00 MB | 66304次下载 | 免费
- 3protel99下载protel99软件下载(中文版)
- 0.00 MB | 51209次下载 | 免费
- 4LabView 8.0 专业版下载 (3CD完整版)
- 0.00 MB | 51043次下载 | 免费
- 5555集成电路应用800例(新编版)
- 0.00 MB | 33562次下载 | 免费
- 6接口电路图大全
- 未知 | 30320次下载 | 免费
- 7Multisim 10下载Multisim 10 中文版
- 0.00 MB | 28588次下载 | 免费
- 8开关电源设计实例指南
- 未知 | 21539次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935053次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537793次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420026次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234313次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233046次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191183次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183277次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138039次下载 | 免费
评论
查看更多