用CAPL通过RS232远程控制ALR3220程控电源

2024-02-07 06:50

本文主要是介绍用CAPL通过RS232远程控制ALR3220程控电源,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

用CAPL通过RS232远程控制ALR3220程控电源

  • 1. ALR3220程控电源
  • 2. ALR3220 远程控制命令
  • 3. 用CAPL控制ALR3220
    • 3.1 首先需要用Panel Designer设计一个控制面板![在这里插入图片描述](https://img-blog.csdnimg.cn/20200711160738847.JPG?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2Zhcm1lcjAw,size_16,color_FFFFFF,t_70#pic_center)
    • 3.2 编写CAPL

1. ALR3220程控电源

在这里插入图片描述
The ALR3220 from ELC is a 0V to 32V, 0 to 20A programmable power supply. It provides protection against short-circuits, by current regulation, against overtemperature by fan and thermal circuit-breaker and against overcurrent on main input, by internal fuses. It has 4 digit graphic LCD 128 x 64 pixels display with white backlight for clear view.

  • Automatic constant voltage operation adjustable voltage of 0 to 32V(0 to ±10mV) with 10mV resolution
  • Automatic constant current operation adjustable current from 0Amps to 20Amps with 10mA resolution
  • Input voltage of 230Volts ±10%, 50 / 60Hz
  • Power consumption of 770W
  • 16 memory configurations
  • USB, RS232 and RS485 interface & 0-10V insulated interface
  • Complies with EN 61326-1, EN 55011, EN 61010-1 and CAT II standards
  • Operating temperature range from +5°C to +40°C
  • Dimension is 155mm x 250mm x 335mm and weight is 3.15Kg
  • LabVIEW drivers and executable provided

由于ALR3220支持RS232通信,那么就可以在开发测试中通过CAPL远程控制输出的电压电流,满足不同的测试要求。

2. ALR3220 远程控制命令

Code0Code1Code2Code3Code4Code5Code6Code7
[address]<sp>Parameter<sp>Command<sp>[Value]<CR>

其中:
[Address] = characters ASCII 0 (RS232 or USB)
characters ASCII 1 to 31 (RS485)
Parameters = VOLT- CURR- OVP-OCP- OUT-RCL-STO (ASCII characters).
Command = WR- RD- MES (ASCII characters).
<SP> = 20h (space).
[Value] = ASCII characters.
<CR> = 0Dh (Enter)
Example 1 : 0 VOLT WR 1250 --> Writing setpoint 1,25 V on RS232 or USB port

Code0Code1Code2Code3Code4Code5Code6Code7
0VOLTWR1250
0x300x200x56,0x4F,0x4C,0x540x200x57,0x520x200x31,0x32,0x35,0x300x0d

Example 2 : 1 CURR MES --> Current measurement request on address 1 from the RS485 port

Answer :
[Address] <SP>Status<SP>Value<CR>
[Address] = characters ASCII 0 (RS232 or USB)
characters ASCII 1 to 31 (RS485)
Status = OK- ERR- Local (ASCII characters).

  • OK Command valid.
  • ERR Syntax error in the command.
  • Local Command impossible, the power supply is in local mode.
    <SP> = 20h (space).
    [Value] = characters ASCII.
    <CR> = 0Dh (retour chariot)
    Example 3 : 0 OK   Back of example 1
    Example 4 : 1 OK 450   Back of example 2 current measurement : 450 mA

3. 用CAPL控制ALR3220

3.1 首先需要用Panel Designer设计一个控制面板在这里插入图片描述

3.2 编写CAPL

variables
{dword  gPortNo=14; /*COM14*/dword  gBaudRate=9600;dword  gDataBits=8;dword  gStopBits=2;dword  gParity = 0;/*0-NOPARITY,1-ODDPARITY,2-EVENPARITY*/// GLOBALconst int kBUFFER_SIZE = 1000;const int kINFO        = 1;const int kWARN        = 2;const int kERROR       = 3;// data is copied from callback buffer to gReceiverBuffer (collects data)byte gReceiverCallbackBuffer[kBUFFER_SIZE];byte gReceiverBuffer[kBUFFER_SIZE];byte gEmptyBuffer   [kBUFFER_SIZE];long gNumberOfReceivedBytes = 0;// state variablebyte gSending = 0;// timer for indication of data reception msTimer tBytesReceived;byte Alr32320CmdEnter= 0x0d;/*<CR> = 0Dh (Enter)*/byte Alr32320CmdSp = 0x20;byte Alr32320WRCmd[2]= {0x57,0x52};/*WR*/byte Alr32320RDCmd[2]= {0x52,0x44};/*RD*/byte AlR3220Volt_Cmd[7]={0x30,0x20,0x56,0x4F,0x4C,0x54,0x20};/*0 VOLT */byte AlR3220Curr_Cmd[7]={0x30,0x20,0x43,0x55,0x52,0x52,0x20};/*0 CURR */byte AlR3220OVP_Cmd[6]={0x30,0x20,0x4F,0x56,0x50,0x20};/*0 OVP */byte AlR3220OCP_Cmd[6]={0x30,0x20,0x4F,0x43,0x50,0x20};/*0 OCP */byte AlR322OutputOnCmd[10]={0x30,0x20,0x4F,0x55,0x54,0x20,0x57,0x52,0x20,0x31};/*0 OUT WR 1*/byte AlR322OutputOffCmd[10]={0x30,0x20,0x4F,0x55,0x54,0x20,0x57,0x52,0x20,0x30};/*0 OUT WR 0*/}on preStart
{InitSerialPort();
}
on envVar EnvSetVoltage
{long numberOfBytes;byte buffer[kBUFFER_SIZE];char volbuf[10];long setvol=0;int i=0;if ( !gSending ){CopyBuffer(buffer,0,AlR3220Volt_Cmd,elCount(AlR3220Volt_Cmd));numberOfBytes = elCount(AlR3220Volt_Cmd);setvol = getValue(EnvSetVoltage);CopyBuffer(buffer,numberOfBytes,Alr32320WRCmd,elCount(Alr32320WRCmd));numberOfBytes+=elCount(Alr32320WRCmd);buffer[numberOfBytes]=Alr32320CmdSp;numberOfBytes = numberOfBytes+1;ltoa(setvol,volbuf,10);for (i=0; i<5; i++){buffer[numberOfBytes+i] = volbuf[i];}numberOfBytes = numberOfBytes+5;buffer[numberOfBytes]=Alr32320CmdEnter;numberOfBytes = numberOfBytes+1;if(0==Rs232Send(gPortNo, buffer, numberOfBytes)){writeLineEx(0,kERROR,"An error occurred during write of block of data to the serial port %d.", gPortNo);return;} else {writeLineEx(0,kINFO, "Write block of bytes to serial port %d worked well.", gPortNo);    }// set stategSending = 1;}
}
on timer tBytesReceived
{/*Process receive data--begin*//*Process receive data--end*/// reset buffergNumberOfReceivedBytes = 0;// reset data indicationputValue(EnvReceptionIndication,0);
}
void InitSerialPort()
{// close serial port (port may have changed, former port shall not remain open)if(Rs232Close(gPortNo)==1)writeLineEx(0,kINFO, "Serial port %d successfully closed.", gPortNo);    elsewriteLineEx(0,kERROR,"An error occurred during closing of the serial port %d.", gPortNo);    // set state (close aborts all open requests)gSending = 0;// open the serial port (comes up with Windows defaults)if(Rs232Open(gPortNo)==1)writeLineEx(0,kINFO, "Serial port %d successfully opened.", gPortNo);    elsewriteLineEx(0,kERROR,"An error occurred during opening of the serial port %d.", gPortNo);// configure the serial port// - just take the panel contentif(Rs232Configure(gPortNo,gBaudRate,gDataBits,gStopBits,gParity)==1)writeLineEx(0,kINFO, "Serial port %d successfully initialized.", gPortNo);    elsewriteLineEx(0,kERROR,"An error occurred during initialization of the serial port %d.", gPortNo); // set buffer for reception (otherwise callback would not work)if(Rs232Receive(gPortNo, gReceiverCallbackBuffer, kBUFFER_SIZE))writeLineEx(0,kINFO, "Receiver buffer for serial port %d successfully set.", gPortNo);    elsewriteLineEx(0,kERROR,"An error occurred during setting the receiver buffer for serial port %d.", gPortNo);
}RS232OnReceive( dword port, byte buffer[], dword number )
{dword numberOfBytesToCopy;// collect data as long as buffer has space for itif ( (gNumberOfReceivedBytes+number)>kBUFFER_SIZE ){numberOfBytesToCopy = kBUFFER_SIZE-gNumberOfReceivedBytes; // no more than that ! it is full now} else {numberOfBytesToCopy = number;}if ( numberOfBytesToCopy==0 ){return; // nothing to add}CopyBuffer(gReceiverBuffer,gNumberOfReceivedBytes,buffer,numberOfBytesToCopy);gNumberOfReceivedBytes += numberOfBytesToCopy; // indicate data receptionputValue(EnvReceptionIndication,1);cancelTimer(tBytesReceived);setTimer(tBytesReceived,500);
}CopyBuffer( byte destBuffer[], dword destOffset, byte srcBuffer[], dword srcNumber )
{dword i;for (i=0; i<srcNumber; i++){destBuffer[destOffset+i] = srcBuffer[i];}
}RS232OnSend( dword port, byte buffer[], dword number )
{// set stategSending = 0;writeLineEx(0,kINFO,"Transmission of %d bytes from port %d completed !", number, port);
}RS232OnError( dword port, dword errorFlags )
{// set stategSending = 0;writeLineEx(0,kERROR,"Error handler called with error code %d !", errorFlags);if ( errorFlags & 1 )writeLineEx(0,1,"%d informs of send error",errorFlags);if ( errorFlags & 2 )writeLineEx(0,1,"%d informs of receive error",errorFlags);if ( errorFlags & 4 )writeLineEx(0,1,"%d informs of frame error",errorFlags);if ( errorFlags & 8 )writeLineEx(0,1,"%d informs of parity error",errorFlags);if ( errorFlags & 16 )writeLineEx(0,1,"%d informs of overrun error",errorFlags);if ( errorFlags & 32 )writeLineEx(0,1,"%d informs of receiver overrun error",errorFlags);if ( errorFlags & 64 )writeLineEx(0,1,"%d informs of break state",errorFlags);if ( errorFlags & 128 )writeLineEx(0,1,"%d informs of send timeout error",errorFlags);
}

这篇关于用CAPL通过RS232远程控制ALR3220程控电源的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/686869

相关文章

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

java程序远程debug原理与配置全过程

《java程序远程debug原理与配置全过程》文章介绍了Java远程调试的JPDA体系,包含JVMTI监控JVM、JDWP传输调试命令、JDI提供调试接口,通过-Xdebug、-Xrunjdwp参数配... 目录背景组成模块间联系IBM对三个模块的详细介绍编程使用总结背景日常工作中,每个程序员都会遇到bu

Java服务实现开启Debug远程调试

《Java服务实现开启Debug远程调试》文章介绍如何通过JVM参数开启Java服务远程调试,便于在线上排查问题,在IDEA中配置客户端连接,实现无需频繁部署的调试,提升效率... 目录一、背景二、相关图示说明三、具体操作步骤1、服务端配置2、客户端配置总结一、背景日常项目中,通常我们的代码都是部署到远程

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

Mac电脑如何通过 IntelliJ IDEA 远程连接 MySQL

《Mac电脑如何通过IntelliJIDEA远程连接MySQL》本文详解Mac通过IntelliJIDEA远程连接MySQL的步骤,本文通过图文并茂的形式给大家介绍的非常详细,感兴趣的朋友跟... 目录MAC电脑通过 IntelliJ IDEA 远程连接 mysql 的详细教程一、前缀条件确认二、打开 ID

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

Spring如何使用注解@DependsOn控制Bean加载顺序

《Spring如何使用注解@DependsOn控制Bean加载顺序》:本文主要介绍Spring如何使用注解@DependsOn控制Bean加载顺序,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录1.javascript 前言2. 代码实现总结1. 前言默认情况下,Spring加载Bean的顺