0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

请问怎样在SCL中去使用浮点数进行计算?

机器人及PLC自动化应用 来源:机器人及PLC自动化应用 作者:微笑应对 2021-07-04 11:32 次阅读

例如,数据类型 REAL 在程序中以 6 位小数的精度进行指定和计算。在计算浮点数(REAL和 LREAL)时,请注意此精度通常应用于每个计算步骤。

在加减浮点数时,将会调整指数。因此在加减过程中,基数和指数将保持不变,仅增加尾数。

在以下编程示例中,将对两个 REAL 数量类型的操作数进行相加,然后再减去一个数。在计算的下一步中,用常量 1 除以前面的结果。为执行此操作,创建一个全局数据块,在其中声明用于进行计算编程的操作数和函数。

计算公式;

y = a + b - c

Z = 1/y

创建数据块“DB_GlobalData”:

1. 双击“添加新块”(Add new block) 命令。

这样会打开“添加新块”(Add new block) 对话框。

2. 单击“数据块 (DB)”(Data block (DB)) 按钮。

3. 指定名称“DB_GlobalData”。

4. 选择“Global DB”作为数据块的类型。

5. 单击“确定”(OK)。

6. 在数据块中创建以下变量,然后输入相应的起始值:

这两个变量的起始值都是 100000000.0,并根据数据类型 REAL 转换为 1.0E+8。

创建一个 SCL 函数并将其命名为“FC_Calculate”。

1. 按如下方式声明块接口

2. 将以下公式写入程序代码并建立在线连接以查看结果:

SCL

#y := "DB_GlobalData".a + "DB_GlobalData".b - "DB_GlobalData".c;

#z := 1/#y;

您可以看到,操作数的运算结果为 #y = 0,即使实际期望数字 1 作为结果也是如此。

不正确的结果产生过程如下:

1. 在第一个计算步骤中,将操作数 a 和 b 相加。在指数调整后,两个操作数(a = 1.000000*108和 b = 1.000000*100)的 REAL 值如下所示:

a = 1.000000*108 且 b = 0.00000001*108。 第二个数字(操作数 b)的最后两位数将被截断,因为 6 位小数的精度无法再表示这个数。 因此,该操作数将会加 0,而不是加 1。

2. 在第二个计算步骤中,将用前面的计算步骤结果减去操作数 C(中间结果 = 1.000000*108 - c = 1.000000*108 为 0.000000e0)。

3. 如果现在计算下一个计算步骤中的操作数 z,则尝试除以 0。

1. 可能的解决方案

要解决此类问题,可以简单地调整计算公式。将公式改为如下所示:

计算公式

y = a - c + b

Z = 1/y

由于在第一个计算步骤(操作数 a - c)后将会得到结果 0.000000e0

在第二个计算步骤中加上 REAL 值(中间结果 + b)就会得到正确的结果 (y = 0.000000*100+ 1.000000*100= 1.000000*100)。

2. 可能的解决方案

要计算上述公式,请使用 LREAL 数据类型来代替 REAL 数据类型。由于此数据类型是以 15位小数的精度进行处理,因此不会产生上述问题。

在全局数据块“DB_GlobalData”中,使用相同的值创建三个全为 LREAL 数据类型的新变量。

在 FC“FC_Calculate”的块接口中,另外声明两个 LREAL 数据类型的新变量。

在程序代码中对公式使用新的 LREAL 变量并建立在线连接以查看结果:

SCL

#y_LREAL := "DB_GlobalData".a_LREAL +"DB_GlobalData".b_LREAL - "DB_GlobalData".c_LREAL;

#z_LREAL := 1/#y_LREAL;

责任编辑:lq6

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 浮点数
    +关注

    关注

    0

    文章

    60

    浏览量

    15874
  • Real
    +关注

    关注

    0

    文章

    17

    浏览量

    13857
  • SCL
    SCL
    +关注

    关注

    1

    文章

    239

    浏览量

    17104

原文标题:在 SCL 中使用浮点数(REAL 和 LREAL)进行计算

文章出处:【微信号:gh_a8b121171b08,微信公众号:机器人及PLC自动化应用】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    ADS1282采集到的数据传到PC上应该怎么转为浮点数

    我最近在用ADS1282,采集到的数据传到PC上应该怎么转为浮点数?比如说通过串口调试助手收到一个采样点的数据为 FF FF 9D 17,它的真实浮点数是多少呢?我知道ADC是以补码形式存的,是要将数据倒转为17 9D FF FF,再与上0xFF,再float()吗?还
    发表于 12-13 06:23

    TLV320AIC3106音频芯片怎么发送、接收浮点数呢?

    TLV320AIC3106 音频芯片怎么发送、接收浮点数呢?是把浮点数转成整数吗?如果是该怎么转呢? 经AD采样后得到的是整数,又该怎么转换成原始的浮点数呢?
    发表于 11-05 07:13

    labview中浮点数与十六进制字符串相互转化

    与下位机数据交流及通讯时,经常有浮点数与十六进制字符串相互转化的需求,经过两天总结,找到了最简洁的相互转化的方法,萌新欢迎大佬指正,文件也附上。*附件:HEX字符串与浮点数转换.rar
    发表于 10-21 19:51

    TMS320C6745浮点数字信号处理器技术简介

    电子发烧友网站提供《TMS320C6745浮点数字信号处理器技术简介.pdf》资料免费下载
    发表于 10-09 09:34 0次下载
    TMS320C6745<b class='flag-5'>浮点数</b>字信号处理器技术简介

    分享arduino 单片机中浮点数转换位数不够,精度丢失的解决办法

    arduino中由于硬件限制,浮点数只有2位小数。但经过这个函数处理可以达到7位
    的头像 发表于 08-27 14:34 757次阅读

    请问AURIX TC3xx tricore架构下浮点运算和将浮点数小数点去掉变成整数来计算哪种方式更加节省算力?

    ? tricore架构下CPU有专门的FPU来处理浮点数运算,是否意味着用12.89参与运算,调用FPU来计算的情况下,计算时间不会比12890参与
    发表于 08-26 06:54

    TMS320C6671定点和浮点数字信号处理器数据表

    电子发烧友网站提供《TMS320C6671定点和浮点数字信号处理器数据表.pdf》资料免费下载
    发表于 08-05 11:17 0次下载
    TMS320C6671定点和<b class='flag-5'>浮点数</b>字信号处理器数据表

    TMS320C6711D浮点数字信号处理器数据表

    电子发烧友网站提供《TMS320C6711D浮点数字信号处理器数据表.pdf》资料免费下载
    发表于 08-03 09:29 0次下载
    TMS320C6711D<b class='flag-5'>浮点数</b>字信号处理器数据表

    官方例程modbus slave rtu,浮点数精度不对是怎么回事?

    官方例程 modbus slave rtu, 浮点数精度不对,对保持寄存器设置一个浮点数,读取到的浮点数结果精度只能到小数点后两位,根本无法使用,用的是idf 5.1.2版本,开发环境是vscode。
    发表于 07-19 08:10

    请问如何打印浮点数或双精度变量?

    如何打印浮点数或双精度变量?
    发表于 07-12 08:24

    ESP8266_RTOS_SDK如何打印浮点数

    尝试使用 printf 打印浮点数,例如, 浮点数 d = 1.0; printf("d = %f", d); 但它打印出来: d = 此外,sprintf
    发表于 07-09 06:56

    如何关闭ESP32-S3中的FPU浮点数计算单元?

    如何关闭ESP32-S3中的FPU浮点数计算单元。如题,之前的项目esp32s2 上面运行良好,但是移植到esp32s3上后由于fpu造成浮点数
    发表于 06-27 07:32

    STM32CubeIDE printf浮点数浮点数丢失数值的原因?

    1、芯片:STM32F103C8T62、环境:STM32CubeIDE3、问题:printf浮点数浮点数数值丢失如 float A=25.6666;float B=24.7777;实际打印
    发表于 06-03 07:07

    verilog语音实现浮点运算

    Verilog可以通过使用IEEE标准的浮点数表示来实现浮点运算。下面是一个基本的Verilog模块示例,展示了如何进行加法、乘法和除法等常见的浮点运算操作: module
    发表于 03-25 21:49

    一文带你秒懂IEEE 754浮点数

    一、简介1、常见的浮点数表示方式是IEEE754标准,它规定了浮点数的存储格式和运算规则,这个标准定义了两种浮点数表示:单精度和双精度。2、任何一个浮点数的二进制数可以写为:NUM=(
    的头像 发表于 03-18 08:09 8861次阅读
    一文带你秒懂IEEE 754<b class='flag-5'>浮点数</b>