`

Eigen的编译选项;MKL的使用

阅读更多
使用时在工程的property页面的如下图所示位置定义(或者在#include <Eigen/Core>前使用#define定义):


1、SSE4.2支持,用Visual Studio时需要手动添加
(但不知道在哪儿用到了SSE4.2):
  • EIGEN_VECTORIZE_SSE4_2

在include最多的Core文件中有这么一段:
引用
    // Detect sse3/ssse3/sse4:
    // gcc and icc defines __SSE3__, ...
    // there is no way to know about this on msvc. You can define EIGEN_VECTORIZE_SSE* if you
    // want to force the use of those instructions with msvc.

更多有关Vectorization的内容参见以下页面的Vectorization一节:
http://eigen.tuxfamily.org/index.php?title=FAQ

2、将矩阵由列优先改为行优先
  • EIGEN_DEFAULT_TO_ROW_MAJOR


3、禁用Eigen的并行化
  • EIGEN_DONT_PARALLELIZE
http://eigen.tuxfamily.org/dox/TopicMultiThreading.html
注意:要想使用OpenMP,除了不能定义以上选项外 ,在Visual Studio中还要设置 "C/C++ -> Language -> OpenMP Support"选项为:Yes (/openmp)

4、使用Intel MKL数学函数库
需要定义:
  • EIGEN_USE_MKL_ALL

我的测试结果:MKL在资源利用和速度上比起Eigen还是有一定的优势的,矩阵越大越明显;但还是不如Matlab,可是Matlab用的也是MKL啊!!!(malab中输入version -lapack查看)。
官方文档:http://eigen.tuxfamily.org/dox/TopicUsingIntelMKL.html
Intel提供的编译选项生成器(能再难用点儿么):https://software.intel.com/en-us/articles/intel-mkl-link-line-advisor/
MKL文档:https://software.intel.com/en-us/articles/intel-math-kernel-library-documentation/
MKL教程:https://software.intel.com/zh-cn/node/529734#88D72261-26DE-42D4-807B-36E48C770AFA
composer xe自行去官网下载,能试用一个月,也不知道是怎么授权的,反正我这台装了一年,卸载后,没法再装了,但别的机器拷过来的编译好的程序,再加上以下的DLL,是可以运行的。。。那么,,MKL的licence在哪一步体现了?

说下配置:Intel Composer XE 2015下载下来不能用(安装时CRC校验不通过。。。),用的是MKL11,也就是2013的版本
由于MKL11不支持VS2013,只好手动配置:

安装路径为:D:\ProgramFiles(x86)\
我只用到了X64的版本:
需要的Include路径:
  • D:\ProgramFiles(x86)\Intel\Composer XE 2013\mkl\include

需要的lib路径:
  • D:\ProgramFiles(x86)\Intel\Composer XE 2013\mkl\lib\intel64
  • D:\ProgramFiles(x86)\Intel\Composer XE 2013\compiler\lib\intel64

需要的lib:
  • mkl_intel_lp64_dll.lib mkl_core_dll.lib mkl_intel_thread_dll.lib mkl_blacs_msmpi_lp64.lib  libiomp5md.lib

运行时需要的DLL:
  • mkl_blacs_lp64.dll
  • mkl_core.dll
  • mkl_intel_thread.dll
  • mkl_mc3.dll
  • mkl_vml_mc3.dll
  • libiomp5md.dll

这些DLL是我试出来的(在没有MKL的机器上运行MKL程序),他们分布在以下两个路径中(运行时还缺DLL的话会弹出提示,提示缺少的DLL,到时可以再去这两个地方找):
(注意第一个是在C盘,而不在安装路径中,该路径安装时会自动被写入环境变量path中)
  • C:\Program Files (x86)\Common Files\Intel\Shared Libraries\redist\intel64\compiler
  • D:\ProgramFiles(x86)\Intel\Composer XE 2013\redist\intel64\mkl

注意:使用MKL时有只bug,即调用m1.householderQr();方法时说该方法重定义!
参见:http://eigen.tuxfamily.org/bz/show_bug.cgi?id=704

某次的实验结果(工程文件见附件):




更多Eigen的编译选项请参见官方文档:
http://eigen.tuxfamily.org/dox/TopicPreprocessorDirectives.html
  • 大小: 45.1 KB
  • 大小: 9.3 KB
分享到:
评论
6 楼 cherishLC 2015-10-12  
Andy__Zou 写道
cherishLC 写道
Andy__Zou 写道
cherishLC 写道
Andy__Zou 写道
您好,您的工程里面的那些hpp文件附件里面没有诶  可否共享下呢

附件重新传了一下,Timer类直接贴到cpp文件里了,另外一个应该不需要。

谢谢!工程里要用到mkl_blacs_msmpi_lp64.lib  libiomp5md.lib库,但是我下载intel mkl的找不到这两个库,能否共享下么?

直接在mkl安装文件夹内搜索啊,不一定是在同一个文件夹里,,带版权的东西不好共享了


我找遍了整个文件夹都没找到这两个库,其它的库都有诶

用我给的网址生成自己的编译选项啊,,不同版本不一样的,我的是11.0的,不可能说MKL安装了不能用的。。。
5 楼 Andy__Zou 2015-10-12  
cherishLC 写道
Andy__Zou 写道
cherishLC 写道
Andy__Zou 写道
您好,您的工程里面的那些hpp文件附件里面没有诶  可否共享下呢

附件重新传了一下,Timer类直接贴到cpp文件里了,另外一个应该不需要。

谢谢!工程里要用到mkl_blacs_msmpi_lp64.lib  libiomp5md.lib库,但是我下载intel mkl的找不到这两个库,能否共享下么?

直接在mkl安装文件夹内搜索啊,不一定是在同一个文件夹里,,带版权的东西不好共享了


我找遍了整个文件夹都没找到这两个库,其它的库都有诶
4 楼 cherishLC 2015-10-09  
Andy__Zou 写道
cherishLC 写道
Andy__Zou 写道
您好,您的工程里面的那些hpp文件附件里面没有诶  可否共享下呢

附件重新传了一下,Timer类直接贴到cpp文件里了,另外一个应该不需要。

谢谢!工程里要用到mkl_blacs_msmpi_lp64.lib  libiomp5md.lib库,但是我下载intel mkl的找不到这两个库,能否共享下么?

直接在mkl安装文件夹内搜索啊,不一定是在同一个文件夹里,,带版权的东西不好共享了
3 楼 Andy__Zou 2015-10-08  
cherishLC 写道
Andy__Zou 写道
您好,您的工程里面的那些hpp文件附件里面没有诶  可否共享下呢

附件重新传了一下,Timer类直接贴到cpp文件里了,另外一个应该不需要。

谢谢!工程里要用到mkl_blacs_msmpi_lp64.lib  libiomp5md.lib库,但是我下载intel mkl的找不到这两个库,能否共享下么?
2 楼 cherishLC 2015-09-26  
Andy__Zou 写道
您好,您的工程里面的那些hpp文件附件里面没有诶  可否共享下呢

附件重新传了一下,Timer类直接贴到cpp文件里了,另外一个应该不需要。
1 楼 Andy__Zou 2015-09-24  
您好,您的工程里面的那些hpp文件附件里面没有诶  可否共享下呢

相关推荐

    树莓派安装yolov5-lite所需的onnxruntime安装包,方便

    4. **编译与安装**:根据树莓派的架构,选择正确的构建选项。对于树莓派4,可以使用以下命令: ``` mkdir build && cd build cmake -Donnxruntime_BUILD_TESTS=OFF -Donnxruntime_ENABLE_MKL_DNN=OFF -...

    visual c++ 环境 矩阵实现 c语言 matrix

    在 Visual C++ 中,你还可以利用向量和矩阵库,如 Intel 的 MKL(Math Kernel Library)或开源的 Eigen 库,它们提供了高效且优化的矩阵运算功能。这些库通常以 C++ 类的形式封装了矩阵操作,并且可能需要更高级的...

    ASP.NET某中学图书馆系统的设计与实现(源代码+论文).zip

    ASP.NET是一种基于.NET框架的服务器端编程模型,用于构建高性能、易于维护的Web应用程序。在这个中学图书馆系统的案例中,开发者利用ASP.NET的技术栈设计并实现了这样一个功能丰富的平台,旨在为中学生、教师以及图书馆管理员提供方便的信息管理和检索服务。下面我们将深入探讨这个系统的核心知识点。 1. **ASP.NET架构**:ASP.NET提供了多种开发模式,如Web Forms、MVC、Web API和Blazor。本系统可能采用了Web Forms或MVC架构,这两种模式都支持事件驱动和模型-视图-控制器(MVC)设计原则,便于创建动态网页和处理用户交互。 2. **数据库设计**:图书馆系统通常需要管理书籍信息、借阅记录、用户账户等数据,因此数据库设计是关键。可能使用了SQL Server或MySQL等关系型数据库,通过ADO.NET或Entity Framework进行数据访问,实现CRUD(创建、读取、更新、删除)操作。 3. **身份验证与授权**:为了确保系统安全,。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    图书管理系统(基于ASP .NET)

    《图书管理系统(基于ASP .NET)》是一款专为学习者设计的应用程序,旨在提供一个全面的图书管理平台。系统的设计采用ASP .NET技术,这是一款由微软开发的用于构建动态网站、web应用和web服务的强大工具。ASP .NET框架以其高效、安全和易于维护的特点,深受开发者的喜爱。 该系统包含了多个核心模块,这些模块覆盖了图书管理的主要功能。有图书录入模块,它允许管理员录入图书的基本信息,如书名、作者、出版社、ISBN号、分类等。图书查询模块提供给用户方便快捷的搜索功能,用户可以根据书名、作者、关键词等条件进行检索。此外,借阅与归还模块确保图书的流通管理,记录图书的借阅状态,提醒用户按时归还,并处理超期罚款等事务。 系统还具备用户管理模块,允许用户注册、登录、修改个人信息。对于权限管理,后台有专门的管理员角色,他们可以对用户进行操作,如分配权限、冻结或解冻账户。同时,系统的统计分析模块能够生成各类报表,如图书借阅量、热门书籍、用户活跃度等,这些数据对于图书馆运营决策有着重要参考价值。 在。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    思维导图制作-会计初级知识重难点-会计务实-会计基础

    本专刊的主要目的是帮助初学者系统化和结构化地掌握会计知识。我们采用思维导图的形式,将复杂的会计概念和流程进行有效的简化,旨在让学习者能够更清晰地理解这些内容,并增强记忆效果。通过视觉化的方式,读者不仅能够感受到会计知识的关联性,还能轻松掌握关键点,提升学习效率。无论是在学习新知识还是复习旧知识时,这种方法都能够为学习者提供极大的便利和帮助。

    精选毕设项目-todolist,带简易后端.zip

    精选毕设项目-todolist,带简易后端

    精选毕设项目-美食菜谱.zip

    精选毕设项目-美食菜谱

    精选毕设项目-地图定位.zip

    精选毕设项目-地图定位

    精选毕设项目-学富网家教电商平台.zip

    精选毕设项目-学富网家教电商平台

    精选毕设项目-乐租租房工具.zip

    精选毕设项目-乐租租房工具

    chromedriver-linux64_123.0.6296.0.zip

    chromedriver-linux64_123.0.6296.0

    永磁同步电机,基于扩展卡尔曼滤波算法无传感器仿真模型,s函数编写算法,基于matlab simulink搭建 附参考资料

    永磁同步电机,基于扩展卡尔曼滤波算法无传感器仿真模型,s函数编写算法,基于matlab simulink搭建。 附参考资料

    factoryio液位PID仿真程序 使用简单的梯形图编写,通俗易懂,起到抛砖引玉的作用,比较适合有动手能力的入门初学者 软件环境: 1、西门子编程软件:TIA Portal V15(博图V15)

    factoryio液位PID仿真程序 使用简单的梯形图编写,通俗易懂,起到抛砖引玉的作用,比较适合有动手能力的入门初学者。 软件环境: 1、西门子编程软件:TIA Portal V15(博图V15) 2、FactoryIO 2.4.0 内容清单: 1、FactoryIO中文说明书+场景模型文件 2、博图V15PLC程序(源码)。

    comsol光学仿真 任意偏振态BIC,利用扭转光子晶体实现远场偏振的调控,包含能带,品质因子计算以及远场辐射偏振椭圆绘制

    comsol光学仿真 任意偏振态BIC,利用扭转光子晶体实现远场偏振的调控,包含能带,品质因子计算以及远场辐射偏振椭圆绘制

    基于STM32的智能家居控制系统.zip

    STM32使用技巧,实战应用开发小系统参考资料,源码参考。经测试可运行。 详细介绍了一些STM32框架的各种功能和模块,以及如何使用STM32进行应用开发等。 适用于初学者和有经验的开发者,能够帮助你快速上手STM32并掌握其高级特性。。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。

    基于数据驱动进化算法的风电场布局优化研究与应用

    内容概要:本文提出了一种数据驱动进化算法(ADE-GRNN)来优化风电场布局,旨在最大化风电场功率输出并减少计算时间。文中引入了自适应差分演化算法和通用回归神经网络来训练数据驱动模型,通过快速过滤低效候选解来提高求解效率。同时详细描述了风力发电机组的位置排布对功率产生成关键影响的因素如湍流效应以及不同算法(ADE、JADE、CLPSO)间的性能对比实验结果。研究表明,在多个评估指标方面,所提出的 ADE-GRNN 方法均表现出显著优势。 适合人群:对于希望深入理解智能算法在工程实践中特别是新能源领域的应用的研发人员和技术爱好者非常适合。 使用场景及目标:用于需要高效能解决复杂组合最优化问题的企业或项目组,特别是在涉及大规模风电场布局规划时的目标定位是提升能源转换率,降低成本消耗,提高运算速度。 其他说明:未来的研究可以进一步考虑更为复杂的风电场拓扑结构及更精确地模拟尾流效应,并探索三维空间下最优布局的可能性;此外还可以尝试不同的机器学习方法来稳定代理模型的表现。

    电流计算方法:.docx

    电流计算方法:.docx

    精选毕设项目-茶叶商城(含后端).zip

    精选毕设项目-茶叶商城(含后端)

    精选毕设项目-化妆品商城.zip

    精选毕设项目-化妆品商城

Global site tag (gtag.js) - Google Analytics