《可编程固定阻值电子负载的制作与自动化标定技术》

一、硬件组成

自制可编程固定电阻电子负载主要由三大核心部件构成:开关电源、串口 232 型 RTU 继电器模块以及 30W 的 RX24 黄金铝壳线绕功率电阻。当前的关键步骤是将这些部件通过焊线进行精准连接,随后将其整体封装于合适的壳体之中,并妥善布置对外接口。在电阻的梯度设计方面,采用的是 2^n 的模式,其中 n = 8,单位为欧姆。


▲ 图1 RTU继电器


▲ 图2 30W功率电阻


▲ 图3 实物

二、电器连接说明

在阻值与 RTU 继电器模块的分配策略上,采用的设计是:继电器的 IO 号与上述电阻梯度分配公式 2^n 中的 n 相等,即 IO1 对应的阻值为 n=1,也就是 2Ω,其余依次类推。此外,所有电阻的另一端均统一连接至继电器的公共端。通过这样的连接方式,既能实现单路选定固定阻值电阻,又能通过多路并联实现阻值的插补。虽然在当前项目中并不需要这种插补功能,但考虑到未来在其他方面的潜在应用需求,此处将其作为冗余设计予以保留。


▲ 图4 实物接线图

三、标定阻值

本阶段工作基于DM3068型数字万用表电阻档,系统标定了电子负载的阻值分布特性,并运用指数函数实现数据拟合。经分析验证,实测关键参数与设计技术规范具有良好的一致性,项目既定目标已达成。下一步计划开展整机集成与外壳封装工艺实施。。

▲ 图5 阻值与IO

python 复制代码
iodim=[1.0000,2.0000,3.0000,4.0000,5.0000,6.0000,7.0000,8.0000]
rdim=[2.3859,4.3510,8.3744,16.4076,32.2679,64.5908,128.2762,257.1318]
python 复制代码
#!/usr/local/bin/python
# -*- coding: gbk -*-
#============================================================
# TEST1.PY                     -- by Dr. BaiChao 2025-12-15
#
# Note:
#============================================================

from headm import *
from tsmodule.tsvisa        import *
import serial
from _ast import Or
from serial.serialutil import SerialException

dm3068open(4)
#------------------------------------------------------------
vi = serial.Serial()
vi.baudrate = 9600
vi.timeout = 1
try:
    vi.port = 'COM8'
except:
    printf('Set vi port COM8 error. ')
try:
    vi.open()
except serial.serialutil.SerialException:
    printf('Open vi port COM8 error.')
else:
    printf('Open vi port COM8 Ok.')
#------------------------------------------------------------
# 继电器控制指令字典
RELAY_COMMANDS = {
    # 第1路
    '1on': b'\x01\x05\x00\x00\xFF\x00\x8C\x3A',
    '1off': b'\x01\x05\x00\x00\x00\x00\xCD\xCA',
    # 第2路
    '2on': b'\x01\x05\x00\x01\xFF\x00\xDD\xFA',
    '2off': b'\x01\x05\x00\x01\x00\x00\x9C\x0A',
    # 第3路
    '3on': b'\x01\x05\x00\x02\xFF\x00\x2D\xFA',
    '3off': b'\x01\x05\x00\x02\x00\x00\x6C\x0A',
    # 第4路
    '4on': b'\x01\x05\x00\x03\xFF\x00\x7C\x3A',
    '4off': b'\x01\x05\x00\x03\x00\x00\x3D\xCA',
    # 第5路
    '5on': b'\x01\x05\x00\x04\xFF\x00\xCD\xFB',
    '5off': b'\x01\x05\x00\x04\x00\x00\x8C\x0B',
    # 第6路
    '6on': b'\x01\x05\x00\x05\xFF\x00\x9C\x3B',
    '6off': b'\x01\x05\x00\x05\x00\x00\xDD\xCB',
    # 第7路
    '7on': b'\x01\x05\x00\x06\xFF\x00\x6C\x3B',
    '7off': b'\x01\x05\x00\x06\x00\x00\x2D\xCB',
    # 第8路
    '8on': b'\x01\x05\x00\x07\xFF\x00\x3D\xFB',
    '8off': b'\x01\x05\x00\x07\x00\x00\x7C\x0B'
}

def set_io(c):
    """
    控制继电器开关状态
    参数c: 继电器控制指令,如'1on', '2off'等
    """
    if c in RELAY_COMMANDS:
        vi.write(RELAY_COMMANDS[c])
        printf(f"执行指令: {c}")
    else:
        printf(f"无效指令: {c}")

#------------------------------------------------------------
iodim = arange(1, 9)
rdim = []
for i in iodim:
    set_io(f"{int(i)}on")
    time.sleep(5)
    r = dm3068res()
    rdim.append(r)
    tspsave("measure", iodim=iodim, rdim=rdim)
    printf(i, r)
    set_io(f"{int(i)}off")
    time.sleep(5)
plt.plot(iodim, rdim, lw=3)
plt.xlabel("Set(IO)", color="steelblue", fontsize=24)
plt.ylabel("Measure(Ω)", color="steelblue", fontsize=24)
plt.grid(True, which='both', linestyle='--', alpha=0.7)
plt.tight_layout()
plt.show()
#------------------------------------------------------------
#        END OF FILE : TEST1.PY
#============================================================


▲ 图6 数据拟合


▲ 图7 指数函数拟合误差

python 复制代码
#!/usr/local/bin/python
# -*- coding: gbk -*-
#============================================================
# TEST2.PY                     -- by Dr. BaiChao 2025-12-16
#
# Note:
#============================================================

from headm import *
from scipy.optimize import curve_fit


#------------------------------------------------------------
iodim,rdim =tspload('measure', 'iodim', 'rdim')
printf(iodim, rdim)
#------------------------------------------------------------
def power_of_two(n):
    return 2**n
#------------------------------------------------------------
rfit = power_of_two(iodim)
errr = rfit - rdim
#------------------------------------------------------------
# plt.plot(iodim, rdim, lw=3, label="Measure")
# plt.plot(iodim, rfit, lw=3, label="Fit")
plt.plot(iodim, errr, lw=3, label="Error")
plt.xlabel("Set(IO)", color="steelblue", fontsize=24)
# plt.ylabel("Measure(R)", color="steelblue", fontsize=24)
plt.ylabel("Error", color="steelblue", fontsize=24)
plt.grid(True, which='both', linestyle='--', alpha=0.7)
plt.tight_layout()
plt.show()



#------------------------------------------------------------
#        END OF FILE : TEST2.PY
#============================================================

总结


本文详细记录了可编程固定阻值电子负载的核心零部件及其制作过程。通过DM3068型数字万用表的电阻档功能,并借助Python脚本程序,实现了电子负载阻值分布特性的自动化标定。进一步利用指数函数对数据进行拟合。经过严谨的分析与验证,项目既定目标已成功达成。

相关推荐
free-elcmacom4 小时前
机器学习高阶教程<2>优化理论实战:BERT用AdamW、强化学习爱SGD
人工智能·python·机器学习·bert·强化学习·大模型训练的优化器选择逻辑
三佛科技-134163842124 小时前
LP3799FAES-B 反激式电源控制器芯片 典型应用电路
单片机·嵌入式硬件·物联网·智能家居·pcb工艺
IT三重门4 小时前
Scikit-Learn进行数据预处理,从基础到实战全解析
python
ULTRA??4 小时前
Informed RRT*算法,并包含圆形障碍物环境
人工智能·python·算法
黑客思维者4 小时前
XGW-9000 网关 DDR4/LPDDR4 内存子系统信号完整性仿真细化设计
开发语言·python·嵌入式硬件·ddr4·信号仿真
Felven4 小时前
华为昇腾310P模型转换失败问题解决
linux·python·模型训练·昇腾·310p
ekprada4 小时前
Day 41 卷积神经网络(CNN)基础与实战
人工智能·python·机器学习
Dingdangcat864 小时前
基于改进YOLO11-C2PSA-SEFFN的工业环境气体泄漏检测与定位系统实现
python
AI视觉网奇4 小时前
live2d 单图转模型 单图生成模型
java·前端·python