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

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

3天内不再提示

在SCL中在计算浮点数REAL和LREAL

机器人及PLC自动化应用 来源:机器人及PLC自动化应用 作者:微笑应对 2022-09-14 16:23 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

例如,数据类型 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. 在数据块中创建以下变量,然后输入相应的起始值:

70a426ae-304c-11ed-ba43-dac502259ad0.png

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

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

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

70d07236-304c-11ed-ba43-dac502259ad0.png

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

SCL

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

#z := 1/#y;

70f295aa-304c-11ed-ba43-dac502259ad0.png

您可以看到,操作数的运算结果为 #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。

710ad4ee-304c-11ed-ba43-dac502259ad0.png

1. 可能的解决方案

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

计算公式

y = a - c + b

Z = 1/y

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

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

7126566a-304c-11ed-ba43-dac502259ad0.png

2. 可能的解决方案

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

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

7141024e-304c-11ed-ba43-dac502259ad0.png

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

71653394-304c-11ed-ba43-dac502259ad0.png

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

SCL

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

#z_LREAL := 1/#y_LREAL;

718789d0-304c-11ed-ba43-dac502259ad0.png




审核编辑:刘清

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

    关注

    1

    文章

    244

    浏览量

    17931

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

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

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    如何使用 ARM FPU 加速浮点计算

    一、浮点数的存储浮点数按照 IEEE 754 标准存储计算机中,ARM浮点环境是遵循 「IEEE 754-1985」 标准实现的。 IEE
    发表于 11-19 06:51

    使用VScode的PIO开发GD32VF103,但是串口无法打印浮点数怎么解决?

    我最近在使用VScode的PIO开发GD32V,使用的是longan的模板,但是我将串口输出重定义到printf函数,发现无法使用%f输出浮点数,想问问应该怎么配置,我看到的一种说法是
    发表于 11-06 06:49

    点数表示实数的方法以及定点数硬件上的运算验证

    ,整数与浮点数做运算时,还需要将整数转化为浮点数才能运算。此外,FPGA,并不能直接支持浮点数运算,需要自己设计相应的
    发表于 10-28 08:13

    E203添加浮点数方法:译码和派遣模块设计

    存在浮点数时应该怎么判断输出数据的选择(选择整数还是浮点数),因此笔者从 dispatch 模块开始讲起。文件 "e203_exu_disp.v" 的代码,出现
    发表于 10-24 13:54

    E203添加浮点数方法:FPU控制逻辑

    指令的全部运算都集中了 FPU 当中。对于指令周期的设计,笔者将除了除法、开方和浮点数存取指令以外的指令都设计为单周期指令(实际为2周期,原因在于 OITF 的原理),这也是为什么原 E203 代码
    发表于 10-24 13:28

    蜂鸟E203扩展浮点指令设计(1)

    : •c.flw 与32位的指令类似 •c.fsw 与32位的指令类似 •c.flwsp是一条 RV32FC 仅有指令,它将一个单精度浮点数值从存储器读入浮点寄存器 rd 。其有效地址的
    发表于 10-24 10:00

    浮点数是如何实现开平方运算的

    。 下图展示了浮点数的平方根计算的基本方案。这里的架构十分通俗易懂。VRSH1块是控制右移块。平方根块能够计算小数的平方根。指数计算路径
    发表于 10-24 08:42

    Vivado浮点数IP核的握手信号

    Vivado浮点数IP核的握手信号 我们的设计方案,FPU计算单元将收到的三条数据和使能信号同步发给20多个模块,同时只有一个模块被时钟使能,进行计算,但结果都会保留,发给数选。
    发表于 10-24 07:01

    浮点数指令添加——长指令写回仲裁

    浮点数指令添加——长指令写回仲裁 增加浮点数指令时,我们会遇到一些需要写回寄存器的指令,此时就需要对原先的写回功能模块做更改。 写回功能主要集中在这两个模块
    发表于 10-24 06:07

    risc-v浮点运算单元的使用及其设计考虑

    的应用。 RISC-V浮点运算单元分为单精度浮点数(32位)和双精度浮点数(64位),通常包括以下几种基本功能: 加法器/减法器:用于
    发表于 10-21 14:46

    大彩讲堂:VisualHMI-LUA教程-获取设置单精度浮点数函数的应用

    软件开发各种协议对浮点数数据进行获取和赋值处理。get_float(vtype,addr)读取单精度浮点数(float)寄存器,返回有符号单精度浮点数·vtype:数
    的头像 发表于 10-16 00:00 1223次阅读
    大彩讲堂:VisualHMI-LUA教程-获取设置单精度<b class='flag-5'>浮点数</b>函数的应用

    PRINTF函数无法打印出浮点数内容是为什么?

    1、MCXN947低功耗adc,历程中使用官方提供的PRINTF无法打印出浮点数内容。 2、同样mcuxpresso ide 也不可以打印浮点数,这是为什么呢? 3、使用的历程是lpadc历程。
    发表于 03-20 08:06

    labview数据类型与PLC 数据类型之间的转换(来自于写入浮点数到汇川 PLC的数据转换关键的修改)

    浮点数默认数据类型是64为双精度浮点数,PLCreal浮点数数据类型,是单精度浮点数32位。
    发表于 02-24 19:01

    西门子TIA Portal如何比较两个浮点数相等

    概述: 由于浮点数的定义规则,导致浮点数不能通过二进制精确表示,所以浮点数计算过程中,会出现两个值一样的
    的头像 发表于 01-06 10:07 1157次阅读
    西门子TIA Portal如何比较两个<b class='flag-5'>浮点数</b>相等

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

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