- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先让我提供一些背景信息,希望它能让问题更清楚:我正在从我希望操作的硬件接收字节向量数据。由于大小和时间限制,我不想将日期转换为更大的大小。我希望允许计算的中间值超出字节范围。这对于标量来说不是问题(中间值保存在寄存器中,编译器不会对中间值发出约束错误)。
但是,在处理用户定义的运算符时,情况会更加棘手。我们可以将结果提升到更大的大小,但随后分配回原始类型将需要显式转换(子类型不能具有混合大小)。例如,在第 24 行下面的代码中将变为 Z := To_Point((X + Y)/2);
这是一种解决方案,但我希望找到一个不需要添加“To_Point”的解决方案“功能。
我查看了 Ada.Numerics 中向量的实现,它使用实数值,并且不提升中间值,例如:
函数“+”(左、右:Real_Vector)返回Real_Vector;
这可能会导致约束误差,但与标量计算(取决于机器)相比,它更有可能导致一些准确性损失(因为实数的表示方式)。
1. pragma Ada_2012;
2. with Ada.Text_IO; use Ada.Text_IO;
3.
4. procedure Inter_Value is
5. type Byte is new Integer Range 0..255 with Size => 8;
6. A, B, C : Byte;
7.
8. type Point is array(1..2) of Byte with Convention => C, Size => 2*8;
9. X, Y, Z : Point;
10.
11. function "+" (Left, Right : Point) return Point is (Left (1) + Right (1), Left (2) + Right(2));
12. function "/" (Left : Point; Right : Byte) return Point is (Left (1) / Right, Left (2) / Right);
13.
14. begin
15. Put_Line(C'Size'Image);
16. A := 100;
17. B := 200;
18. C := (A + B) / 2; -- Ok, intermediate value in register
19. Put_Line("C = " & C'Image);
20.
21. Put_Line(X'Size'Image);
22. X := (100, 100);
23. Y := (200, 200);
24. Z := (X + Y) / 2; -- CONSTRAINT_ERROR, intermediate value in Point
25. Put_Line("Z = " & Z(1)'Image & Z(2)'Image);
26. end;
最佳答案
回顾一下评论:Byte
的声明相当于
type Byte'Base is new Integer;
subtype Byte is Byte'Base range 0 .. 255 with Size => 8;
重要的是预定义运算符是为Byte'Base
定义的。要获得类似的 Point
行为,您必须显式模仿:
type Point_Base is array (1..2) of Byte'Base;
function "+" (Left : in Point_Base; Right : in Point_Base) return Point_Base is
(Left (1) + Right (1), Left (2) + Right(2) );
function "/" (Left : in Point_Base; Right : in Byte'Base) return Point_Base is
(Left (1) / Right, Left (2) / Right);
subtype Point is Point_Base with
Dynamic_Predicate => (for all P of Point => P in Byte);
现在 (X + Y)
给出一个 Point_Base
并传递给 "/"
,它还给出一个 Point_Base
。然后在赋值之前检查结果是否满足 Z
子类型的约束。
关于Ada:在向量上提升用户定义运算符的中间值的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67656008/
Or 运算符 对两个表达式进行逻辑“或”运算。 result = expression1 Or expression2 参数 result 任意数值变量。 expression1 任意
Not 运算符 对表达式执行逻辑非运算。 result = Not expression 参数 result 任意数值变量。 expression 任意表达式。 说明 下表显示如何
Is 运算符 比较两个对象引用变量。 result = object1 Is object2 参数 result 任意数值变量。 object1 任意对象名。 object2 任意
\ 运算符 两个数相除并返回以整数形式表示的结果。 result = number1\number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
And 运算符 对两个表达式进行逻辑“与”运算。 result = expression1 And expression2 参数 result 任意数值变量。 expression1
运算符(+) 计算两个数之和。 result = expression1 + expression2 参数 result 任意数值变量。 expression1 任意表达式。 exp
我对此感到困惑snippet : var n1 = 5-"4"; var n2 = 5+"4"; alert(n1); alert(n2); 我知道 n1 是 1。那是因为减号运算符会将字符串“4”转
我想我会得到 12,而不是 7。 w++,那么w就是4,也就是100,而w++, w 将是 8,1000;所以 w++|z++ 将是 100|1000 = 1100 将是 12。 我怎么了? int
Xor 运算符 对两个表达式进行逻辑“异或”运算。 result = expression1 Xor expression2 参数 result 任意数值变量。 expression1
Mod 运算符 两个数值相除并返回其余数。 result = number1 Mod number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
Imp 运算符 对两个表达式进行逻辑蕴涵运算。 result = expression1 Imp expression2 参数 result 任意数值变量。 expression1 任
Eqv 运算符 执行两个表达式的逻辑等价运算。 result = expression1 Eqv expression2 参数 result 任意数值变量。 expression1 任
我有一个运算符重载的简单数学 vector 类。我想为我的运算符(operator)获取一些计时结果。我可以通过计时以下代码轻松计时我的 +=、-=、*= 和/=: Vector sum; for(s
我是用户定义比较运算符的新手。我正在读一本书,其中提到了以下示例: struct P { int x, y; bool operator、运算符<等),我们
在 SQL 的维基百科页面上,有一些关于 SQL 中 bool 逻辑的真值表。 [1] 维基百科页面似乎来源于 SQL:2003 标准。 等号运算符 (=) 的真值表与 SQL:2003 草案中的 I
我遇到了一个奇怪的 C++ 运算符。 http://www.terralib.org/html/v410/classoracle_1_1occi_1_1_number.html#a0f2780081f
我正在阅读关于 SO 和 answers 中的一个问题,它被提到为: If no unambiguous matching deallocation function can be found, pr
我偶然发现了这个解决方案,但我无法理解其中到底发生了什么。谁能解释一下! 据我了解,它试图通过计算一半的单元格然后将其加倍来计算 a*b 网格中的单元格数量。但是我无法理解递归调用。 请不要建议其他解
Go的基本类型 布尔类型bool 长度:1字节 取值:布尔类型的取值只能是true或者false,不能用数字来表示 整型 通用整型 int / uint(有符号 / 无符号,下面也类似) 长度:根据运
在本教程中,您将学习JavaScript中可用的不同运算符,以及在示例的帮助下如何使用它们。 什么是运算符? 在JavaScript中,运算符是一种特殊符号,用于对运算数(值和变量)执行操作。例如,
我是一名优秀的程序员,十分优秀!