- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我试图让我的代码自动矢量化,但它不起作用。
int _tmain(int argc, _TCHAR* argv[])
{
const int N = 4096;
float x[N];
float y[N];
float sum = 0;
//create random values for x and y
for (int i = 0; i < N; i++)
{
x[i] = rand() >> 1;
y[i] = rand() >> 1;
}
for (int i = 0; i < N; i++){
sum += x[i] * y[i];
}
}
这两个循环都没有向量化,但我真的只对第二个循环感兴趣。
我正在使用 visual studio express 2013 并使用 /O2
和 /Qvec-report:2
进行编译(报告循环是否被矢量化)选项。编译时,我收到以下消息:
--- Analyzing function: main
c:\users\...\documents\visual studio 2013\projects\intrin3\intrin3\intrin3.cpp(28) : info C5002: loop not vectorized due to reason '1200'
c:\users\...\documents\visual studio 2013\projects\intrin3\intrin3\intrin3.cpp(41) : info C5002: loop not vectorized due to reason '1305'
原因'1305',可见HERE ,表示“编译器无法识别此循环的正确矢量化类型信息。”我不太确定这是什么意思。有什么想法吗?
将第二个循环拆分成两个循环后:
for (int i = 0; i < N; i++){
sumarray[i] = x[i] * y[i];
}
for (int i = 0; i < N; i++){
sum += sumarray[i];
}
现在上述循环中的第一个进行矢量化,但第二个没有进行矢量化,同样出现错误代码 1305。
最佳答案
错误 1305 的发生是因为优化器没有对循环进行向量化,因为未使用值 sum
。只需添加 printf("%d\n", sum)
即可解决此问题。但是随后您会收到一个新的错误代码 1105“循环包含无法识别的缩减操作”。要解决此问题,您需要设置 /fp:fast
原因是浮点运算不是关联的,使用 SIMD 或 MIMD(即使用多线程)的归约需要关联。通过使用更宽松的浮点模型,您可以进行缩减。
我刚刚使用以下代码对其进行了测试,默认的 fp:precise
不进行矢量化,而当我使用 fp:fast
时,它进行矢量化。
#include <stdio.h>
int main() {
const int N = 4096;
float x[N];
float y[N];
float sum = 0;
for (int i = 0; i < N; i++){
sum += x[i] * y[i];
}
printf("sum %f\n", sum);
}
关于您关于使用 rand()
函数进行循环的问题,rand()
函数不是 SIMD 函数。它不能被矢量化。您需要找到一个 SIMD rand() 函数。我不知道一个。另一种方法是预先计算一个随机数数组,然后使用该数组。无论如何,rand()
是一个可怕的随机数生成器,仅对某些玩具箱有用。考虑使用 Mersenne twister PRNG。
关于c++ - 自动矢量化不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23378889/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!