【发布时间】:2012-03-03 21:47:41
【问题描述】:
这是一个非常有趣的问题,所以让我来设置一下场景。我在国家计算机博物馆工作,我们刚刚设法让一台 1992 年的 Cray Y-MP EL 超级计算机运行起来,我们真的很想看看它的速度有多快!
我们认为最好的方法是编写一个简单的 C 程序来计算素数并显示计算所需的时间,然后在快速的现代台式 PC 上运行该程序并比较结果。
我们很快想出了这个代码来计算素数:
#include <stdio.h>
#include <time.h>
void main() {
clock_t start, end;
double runTime;
start = clock();
int i, num = 1, primes = 0;
while (num <= 1000) {
i = 2;
while (i <= num) {
if(num % i == 0)
break;
i++;
}
if (i == num)
primes++;
system("clear");
printf("%d prime numbers calculated\n",primes);
num++;
}
end = clock();
runTime = (end - start) / (double) CLOCKS_PER_SEC;
printf("This machine calculated all %d prime numbers under 1000 in %g seconds\n", primes, runTime);
}
在我们运行 Ubuntu(The Cray 运行 UNICOS)的双核笔记本电脑上运行良好,获得 100% 的 CPU 使用率,大约需要 10 分钟左右。回到家后,我决定在我的六核现代游戏 PC 上尝试一下,这就是我们遇到的第一个问题。
我首先将代码修改为在 Windows 上运行,因为这是游戏 PC 所使用的,但很遗憾地发现该进程仅获得了 CPU 功率的 15% 左右。我想这一定是 Windows 就是 Windows,所以我启动到 Ubuntu 的 Live CD 中,认为 Ubuntu 将允许该进程充分发挥其潜力,就像它之前在我的笔记本电脑上所做的那样。
但是我只有 5% 的使用率!所以我的问题是,我怎样才能使程序在我的游戏机上以 100% 的 CPU 利用率在 Windows 7 或 Live Linux 上运行?另一件很棒但不必要的事情是,最终产品是否可以是一个可以轻松分发并在 Windows 机器上运行的 .exe。
非常感谢!
附:当然,这个程序并不能真正与 Crays 8 专业处理器一起工作,那完全是另外一回事了……如果你知道任何关于优化代码以在 90 年代 Cray 超级计算机上工作的知识,也请给我们留言!
【问题讨论】:
-
我不敢相信没有 unicos 标记。 ;)
-
奇怪的是,这个单线程程序在双核处理器上占用了 100% 的 CPU 使用率)))
-
只有我觉得这个问题一点都不有趣吗?来一个,在 n 核机器上运行一个单线程程序并询问它为什么使用 1/n 的 cpu 只是......没关系,我只是投反对票:-)
-
@drhirsch 好吧,这个问题显示了研究工作。我为此 +1 了 - 即使 OP 缺少关于多核计算的一些基本知识。
-
@drhirsch 网站上有很多无趣的问题。然而,有趣与否是主观的。他可能缺少基本面,这不是主观的。就像 Mystical 所说的那样,它确实显示了研究成果,但并不像看起来那么容易回答。
标签: c windows linux performance cray