这个程序的主要功能是展示如何使用模拟电压反馈来控制运动控制器的速度。程序通过读取模拟信号(ADC值),将其乘以一个常数来计算所需的速度,并将这个速度设置到运动控制器的指定轴上。这个过程在每个循环迭代中重复进行,直到检测到轴关闭状态为止。
程序的执行逻辑可以概括为以下几个步骤:
-
初始化:定义和初始化所需的变量,包括板卡ID、轴编号、通信状态寄存器、轴状态、常数乘数和ADC值。
-
配置运动参数:设置轴的初始速度、加速度、减速度和急动(S-曲线值)。
-
设置操作模式:将轴的操作模式设置为速度控制模式。
-
启动运动:启动轴的运动。
-
循环读取和更新:进入一个循环,不断读取ADC值,根据ADC值更新轴的速度,并启动更新后的速度。
-
错误和状态检查:在循环中检查轴的状态和通信状态寄存器,以确定是否有错误发生或轴是否关闭。
-
退出条件:当检测到轴关闭时,退出循环并结束程序。
-
错误处理:如果在通信状态寄存器中检测到模态错误,程序将从错误堆栈中获取错误信息并显示它们,然后退出程序。
这个程序是一个基于模拟反馈控制速度的 Win32 控制台应用程序。它展示了如何根据读取到的模拟电压来控制运动速度。程序使用了 National Instruments 的 FlexMotion 软件库来实现这一功能。
///
// 要求:FlexMotion 软件版本 5 或更新版本。
//
// 使用导入库:
// <NI-Motion 安装位置>\FlexMotion\lib\Microsoft\FlexMS32.lib
// 对于 MS 编译器,以及
// <NI-Motion 安装位置>\FlexMotion\lib\Borland\FlexBC32.lib
// 对于 BC 编译器
//
// 在您的项目包含目录中添加包含路径:
// <NI-Motion 安装位置>\FlexMotion\Include
// <NI-Motion 安装位置>\FlexMotion\Examples\C\Includes
//
// 将常见源代码添加到您的项目中:
// <NI-Motion 安装位置>\FlexMotion\Examples\C\Includes\NIMCExample.c
//
// 其中 <NI-Motion 安装位置> 默认是
// <驱动器>\Program Files\National Instruments\NI-Motion
// 对于 32 位 Windows
// <驱动器>\Program Files (x86)\National Instruments\NI-Motion
// 对于 64 位 Windows
//
// 描述:
// 此 C 示例展示了基于读取的模拟电压控制速度的方法
//
///
// 包含 //
#include "flexmotn.h" // FlexMotion 相关的头文件
#include "NIMCExample.h" // NIMC 示例相关的头文件
#include <stdio.h> // 标准输入输出库
#include <stdlib.h> // 标准库,包含内存操作函数等
//
// 主函数
void main(void)
{
u8 boardID; // 板卡标识号
u8 axis; // 轴编号
u16 csr = 0; // 通信状态寄存器
u16 axisStatus; // 轴状态
i32 constant; // 常数乘数
i16 adcValue; // 读取的 ADC 值
// 模态错误处理的变量
u16 commandID; // 函数的 commandID
u16 resourceID; // 资源 ID
i32 errorCode; // 错误代码
// 设置板卡 ID
boardID = 1;
// 设置轴编号
axis = 1;
// 乘以 ADC 值读取以计算所需速度的常数
constant = 10;
// 设置移动的速度(以计数/秒为单位)
err = flex_load_velocity(boardID, axis, 10000, 0xFF);
CheckError;
// 设置移动的加速度(以计数/秒^2为单位)
err = flex_load_acceleration(boardID, axis, NIMC_ACCELERATION, 100000, 0xFF);
CheckError;
// 设置移动的减速度(以计数/秒^2为单位)
err = flex_load_acceleration(boardID, axis, NIMC_DECELERATION, 100000, 0xFF);
CheckError;
// 设置移动的急动(S-曲线值)(以采样周期为单位)
err = flex_load_scurve_time(boardID, axis, 100, 0xFF);
CheckError;
// 将操作模式设置为速度控制
err = flex_set_op_mode(boardID, axis, NIMC_VELOCITY);
CheckError;
// 启动移动
err = flex_start(boardID, axis, 0