当前位置:   article > 正文

安时积分法的c语言程序,代码生成 | 安时积分法模型搭建

安时积分法c语言实现

安时积分法是电池电量计量最基础的方法,今天我们用simulink建模的方式做一个安时积分模型,从而更好地理解安时积分的思想也掌握建模的基础操

​新建文件

打开MATLAB启动simulink新建一个模型文件

626078fa8417a7e7306615c9150f9d32.png定义变量

和手写代码一样,先定义几个后面要用到的变量,在simulink建模时新建变量用Data Store Memory模块。双击填入要定义的变量名,然后在signal attributes赋初值

b5131a86f5478e4f58a9440db440ba94.png

4da504ad56010c9f010bf06654ee5f50.png

如此方法新建四个变量current(电流)初值1000mA、tatol_cap(总容量)初值2Ah、now_cap(当前容量)初值3600、soc(电量);

dc73356ec560784b495b8ac9b957cceb.png

当鼠标放置在Data Store Memory模块上时左右两边会出来两个箭头,按住鼠标拖动左边的箭头可以出来Data Store Write也就是写变量给变量写入一个值,拖动右边的箭头可以出来Data Store Read即读出变量的值;

06123c704c340a27cc418ac383857070.png

搭建模型

先把current的单位换算成mA用到了gain模块除以1000,时间单位为1累计的电流和当前容量加和用到的add模块再将新值赋给now_cap

ce989cc5c1566623a841b2a335d7281e.png

对总容量进行单位转换将Ah乘以3600分别用到常数模块和乘法运算模块这样上半部分和下半部分的单位都是As

070119a21f86ee0681a9bda174d66a66.png

最后用当前容量除以总容量就得出了SOC,添加几个显示模块便于验证结果

2e82f3c3f1890a0d0830e1a5a5755b62.png

验证结果

点击设置仿真,由于处理器不是连续系统,处理速度和频率有关因此要设置为定步长,stop time设为1 步长为0.1也就是计算10次

fcb1470f526b7103e4e2646baa55cceb.png

运行结果显示当前SOC为50.15%,当前容量是3610由于now_cap的初值3600As也是1Ah加上1A电流对时间10次积分的结果整好是3610,当然改变仿真步长或者时长仿真结果也会发生变化。

783a4acf81bc47f6f4f207dc88808922.png生成代码

进一步设置仿真生成代码,选择tlc文件也是就你要将模型翻译成那种语言

0fd1f887642940e11bd9628fa883f545.png

勾选生成报告,点击生成代码

92ecb035d5510706111fc937a7f928af.png

生成代码的报告

cc022b0be3397b1824155acf3bb4b848.png

可以看到生成的代码和我们手动写的代码一样

86cd9aaa3effa39fc356943c232e2dcb.png

生命不息、学习不止,加油!

本文地址:https://blog.csdn.net/ningvay/article/details/107295357

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/870502
推荐阅读
相关标签
  

闽ICP备14008679号