C#/C++/Fortran 在32位/64位下数学计算性能对比-程序员宅基地

技术标签: c#  人工智能  c/c++  

测试平台

在我的上一篇博客中对比了VS2010中C#和C++在运算密集型程序中的性能。上一篇博客的链接:

http://www.cnblogs.com/ytyt2002ytyt/archive/2011/11/24/2261104.html

当时是在AMD 速龙9650 CPU(4核心)下的测试结果。

 

随着VS2012、Intel Parallel Studio XE 2013中新一代编译器的发布,再测试一下VC11编译器相对于VC10的提升,以及.net4.5 .net4.0对C#的性能区别。Fortran则使用了最新的 Intel Parallel Studio XE 2013。另外Fortran作为老牌的科学计算语言,也试图重点测试一下相对于现代主流编程语言C++和C#在性能上的差异。Fortran作为汇编后最早诞生的编程语言,其矩阵运算非常方便,几十年间长期占据了性能上的宝座。Fortran 90/95、Fortran2003/2008 又加入大量现代语言特性,在20年前就内置了并行化的支持。

 

测试平台:

CPU Intel Xeon E3 1230v2 3.5G 4核8线程

Win7 64bit

编译器:

C++          VC11(VS2012)

Fortran      Intel Parallel Studio XE 2013

C#           .net4.0 .net4.5

 

测试代码

不过为了公平起见,下列的测试中只使用了一个线程,没有并行化,也没有矩阵运算,均为默认参数编译。

C#和C++代码和之前的测试程序一样

C++代码:

C++代码#include <stdio.h> 
#include <stdlib.h> 
#include <time.h> 
#include <math.h> 

//为cin cout 提供
#include <iostream>
using namespace std;

#define INTEG_FUNC(x) fabs(sin(x)) //计算公式

double dclock(void); 

int main(void) 
{ 
	unsigned int i, j, N; 
	double step, x_i, sum; 
	double start, finish, duration, clock_t; 
	double interval_begin = 0.0; 
	double interval_end = 2.0 * 3.141592653589793238; 

	start = clock(); //初始时间

	printf(" \n"); 
	printf(" Number of中文 | Computed Integral | \n"); //Win7下中文显示正常
	printf(" Interior Points | | \n"); 

	for (j=2;j<27;j++) 
	{  
		N = 1 << j;

		step = (interval_end - interval_begin) / N; 
		sum = INTEG_FUNC(interval_begin) * step / 2.0; 

		for (i=1;i<N;i++) 
		{ 
			x_i = i * step; 
			sum += INTEG_FUNC(x_i) * step; 
		} 

		sum += INTEG_FUNC(interval_end) * step / 2.0; 

		//printf(" %10d | %14e | \n", N, sum); 
		printf(" %14e  \n", sum); 
	} 

	finish = clock(); //结束时间
	duration = (finish - start); 
	printf(" \n"); 
	printf(" time = %10e \n", duration); 
	printf(" \n"); 

	int tempA;
	cin>>tempA;

	return 0; 
}

C#代码:

C#代码using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            int time = System.Environment.TickCount;  //添加计时器

            #region
            int i, j, N;
            double step, x_i, sum;
            double start, finish, duration, clock_t;
            double interval_begin = 0.0;
            double interval_end = 2.0 * 3.141592653589793238;

            for (j = 2; j < 27; j++)
            {
                N = 1 << j;
                step = (interval_end - interval_begin) / N;
                sum = Math.Abs(Math.Sin(interval_begin)) * step / 2.0;

                for (i = 1; i < N; i++)
                {
                    x_i = i * step;
                    sum += Math.Abs(Math.Sin(x_i)) * step;
                }

                sum += Math.Abs(Math.Sin(interval_end)) * step / 2.0;
                Console.Write(sum.ToString() + "\r\n");
            }

            Console.Write((System.Environment.TickCount - time).ToString());
            Console.ReadLine();
            #endregion
        }
    }
}

 

Fortran代码:

image

 

Fortran代码program ForAllProgram
	implicit none
	real(8) :: time1,time2
	integer :: i,j,k,N
	real(8) :: step, x_i, s
	real(8) :: interval_begin = 0.0
	real(8) :: interval_end = 2.0 * 3.141592653589793238
	real, allocatable :: ArrySum(:)	!          
	
	call CPU_TIME(time1)
	do j = 2, 26
		N=2**j !N = 1 << j;  位操作用乘方操作代替
		step = (interval_end - interval_begin) / N;
        s = Abs(Sin(interval_begin)) * step / 2.0;
				
		do i = 1, N-1 !这里对应于C++的<N是N-1
			x_i = i * step;
            s =s+ Abs(Sin(x_i)) * step;
		end do
		s =s+ Abs(Sin(interval_end)) * step / 2.0;
		print *, s
	end do
	call CPU_TIME(time2)
	print *,time2-time1
	
end program

注意Fortran中用乘方代替了位操作,另外Do循环到N-1对应于C++中的<N

 

测试结果

image

 

时间单位:毫秒

image

时间单位:毫秒 越小越好

image

测试结论

C#在.net 4.5 和.net 4.0相比,性能只是在.net4.5的32bit中略有提升。奇怪的是.net4.5中,32bit的性能居然高于64bit的性能。

C++ 在VS2012比VS2010有了显著的提升,微软的C++CX 性能可能和Intel的C++性能相近了。64bit性能显著高于32bit性能。

Fortran在运算密集型的问题中,性能极其恐怖,甚至超常我原本的想象。未加任何优化,性能超过C++的3倍,是C#的5-6倍。数值计算的王者看了还是非Fortran莫属。如此高的性能可能是因为:默认即可充分利用到Simd向量化(本机的AVX指令集)。而C++即使启用了Intel的向量化编译(Intel默认是启用的),因为复杂的语法也很难充分实现自动向量化。需要加入向量化编译指令,如#program simd 等,甚至需要手工编码向量化(如OpenCV中的优化实现)。这样程序优化的工作量和程序复杂度将会大为提升。

可见进行大规模科学计算,Fortran仍然是最适合的选择,再加上大量现存的数学计算类库都是由Fortran编写,语法也相对简单,确实是数值计算的绝配。

C++在与系统底层交互中则有先天的优势;C#适合表现层开发和整体架构设计,最为便捷优雅。

 

展望

下一篇将继续测试CPU并行化以及GPU加速的性能。根据以往的经验,GTX460级别的显卡在float类型的计算中,优化后能达到CPU单线程的10-20倍性能。但考虑到CPU多核心并行后,以及Fortran向量化恐怖的性能,估计最终GPU的优势不会那么大,可能只有2-3倍的优势吧。对于双精度计算,由于桌面级显卡的双精度只有单精度的1/8(tesla运算卡是1/2,但价格昂贵,最新的开普勒110架构tesla k20 和Titans则是1/3,理论双精度超过1T ),所以估计费米核心tesla双精度也只能达到8线程CPU并行的2-3被,开普勒或许能更高些。不过这些只是推测,待到下次测试后才能见分晓。

 

本文地址: 杨韬的学习备忘录 http://www.cnblogs.com/ytyt2002ytyt/archive/2013/04/02/2996718.html

转载于:https://www.cnblogs.com/ytyt2002ytyt/archive/2013/04/02/2996718.html

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_30784141/article/details/96977407

智能推荐

计算机的外围设备简介_计算机外围固定-程序员宅基地

文章浏览阅读6.1k次,点赞3次,收藏5次。外围设备介绍计算机的外围设备(简称外设)虽然很多,但按功能分大类只有四类:输入、输出、存储、网络通讯。有些专业计算机需要的外围设备也不尽相同,并不都需要这四类外围设备。外围设备可以按需要组装,有些专业计算机甚至可以将存储设备和主芯片集成到一片芯片上,从而不再需要外加存储设备。最早的计算机(那时还只能称为计算器,只能做简单运算,如ABC机和ENIAC机)输入只是一些拨码开关,只能输入数字(还得是二进_计算机外围固定

java 图片中加文字_java怎么在图片上加文字-程序员宅基地

文章浏览阅读1.5k次。java 图片中加文字_java怎么在图片上加文字

GBase8cGDCA认证模拟题题库(三)_如果需要打开delete语句的审计功能,需要开启下面哪个参数-程序员宅基地

文章浏览阅读720次,点赞20次,收藏6次。B 选项,在创建模式时,可以不指定模式名。C 选项,兼容模式可选值为 AB、C、PG.安装GBase 8c分布式集群时所需的配置文件gbase.yml,在解压GBase8cV5 S3.0.0BXX CentOS x86 64.tar.bz2压缩包生成的目录中得到。真值的有效文本值是: TRUE、t、"true'、y、yes'、"1'TRUE'、true、整数范围内1~2^63-1、整数范围内-1~-2^63。GBase 8c 使用create table 创建表时,不指定参数,默认是astore,行存表。_如果需要打开delete语句的审计功能,需要开启下面哪个参数

xml文件中几个名词_xml文件里面的名词-程序员宅基地

文章浏览阅读334次。1 xmlns是XML Namespaces的缩写,中文名称是XML(标准通用标记语言的子集)命名空间。 web-app是web.xml的根节点标签名称 version是版本的意思 xmlns是web.xml文件用到的命名空间 xmlns:xsi是指web.xml遵守xml规范 xsi:schemaLocation是指具体用到的schema资源_xml文件里面的名词

【OpenGL】中点圆、椭圆生成算法_用setpixel函数中点画圆算法代码c++-程序员宅基地

文章浏览阅读1.6w次,点赞12次,收藏69次。OpenGL 中点圆、椭圆生成算法_用setpixel函数中点画圆算法代码c++

HTML-CSS实现背景图片出现不同的位置_css背景图高度占据一半另一半有别的背景色-程序员宅基地

文章浏览阅读2.1k次。首先在HTML中写入div,命名为img,在这个div中加入一个span标签并命名为img-bg和img50(5星为50).<div class="img"> <span class="img-bg img50"></span> <span class="img-bg img45"></span> <span class="img-bg img40"></span> </div> 在css代码._css背景图高度占据一半另一半有别的背景色

随便推点

matlab建模DNA双链,PPT绘制科研图形—DNA双链、分子细胞模型-程序员宅基地

文章浏览阅读1.3k次。原标题:PPT绘制科研图形—DNA双链、分子细胞模型 PPT绘制DNA双链 1用矩形工具画一个矩形如下,线条颜色设置为无,填充色如下图蓝色 2选中矩形框,选择菜单栏的“格式—— 编辑形状——转换为任意多边形” 3这个时候再看下“编辑形状”,可以看到“编辑顶点” 已经为可用状态 4点击“编辑顶点“,矩形框四个角变为黑色实点。可以拖动实点变为如下图示。然后在边缘上右键,选择”添加顶点“,添加如下顶点 ..._matlab双螺旋结构模型图怎么画

duilib vs2015 安装_DuiLib(1)——简单的win32窗口-程序员宅基地

文章浏览阅读169次。资源下载https://yunpan.cn/cqF6icWRN5CTc 访问密码 92e3 注:DUILIB库.7z 是vs2015下编译好的动态库及静态库,如上图所示一、新建一个win32工程项目设置中选择:debug,常规中:全程无优化-全程无优化,多线程调试 (/MTd);我的项目选择的是静态编译,使用的是静态库,就不需要带duilib.dll文件了代码如下:#include #inclu..._vs2015使用duilib

OpenGL: 渲染管线理论详解_通过此次实验你对固定渲染管线的opengl编程有什么了解。-程序员宅基地

文章浏览阅读5k次,点赞4次,收藏13次。学习着色器,并理解着色器的工作机制,就要对OpenGL的固定功能管线有深入的了解。首先要知道几个OpenGL的术语:渲染(rendering):计算机根据模型(model)创建图像的过程。模型(model):根据几何图元创建的物体(object)。几何图元:包括点、直线和多边形等,它是通过顶点(vertex)指定的。 最终完成了渲染的图像是由在屏幕上绘制的像素组成的。在内存中,和像素有关的信息(如像素的颜色)组织成位平面的形式,位平面是一块内存区域,保存了屏幕上每个像素的一个位的信息。_通过此次实验你对固定渲染管线的opengl编程有什么了解。

Android MPAndroidChart:动态添加统计数据线【8】_android 动态统计-程序员宅基地

文章浏览阅读3.9k次。Android MPAndroidChart:动态添加统计数据线【8】本文在附录相关文章6的基础上,动态的依次增加若干条统计折线(相当于批量增加数据点)。布局文件:

vmware中的linux虚拟机如何增加磁盘容量_linux虚拟机磁盘空间不足-程序员宅基地

文章浏览阅读6.3k次。vmware中 centos的磁盘大小 20G->30G现象:fdisk -l可以看到增大后的磁盘总量,但是需要增加分区并格式化然后挂载才能使用.一、vmware中的设置先关闭虚拟机vm->settings->hard disk->utilities->expand->输入大小(增加后的大小)二、启动虚拟机,进入命令行1、 fdisk /dev/sda进入命令行Comman_linux虚拟机磁盘空间不足

Hadoop2.7.3下Mysql8.0下Hive2.3.8的安装_hive2.3.8安装-程序员宅基地

文章浏览阅读927次。hive安装前提:1.基于hadoop2.7的完全分布式集群搭建完成hadoop2.7集群搭建2.MySQL8.0安装完成 安装centos7上MySQL8.0Hive2.3.8的安装下载链接:https://mirrors.tuna.tsinghua.edu.cn/apache/下滑找到hive点击进去点击hive2.3.9(hive2.3.9和hive2.3.8差别不大)下载画红线的也就是bin.tar.gz后缀的hive解压安装下载完成后通过xftp传到虚拟机上(基操不在赘述)_hive2.3.8安装

推荐文章

热门文章

相关标签