Intel® MKL-DNN

article/2025/9/14 6:25:59

Intel® MKL-DNN

在现代英特尔架构中,缓存和内存使用效率会对整体性能产生显著影响。良好的内存访问模式可以最大限度地降低访问内存数据的额外成本,不会降低整体处理速度。若要实现这一目标,数据的存储和访问方式起着重要作用。这通常被称为数据布局。它描述了多维数组如何在内存地址空间中线性存储。

1. Intel® Math Kernel Library for Deep Neural Networks (Intel® MKL-DNN)

数据布局由二维图像的 四个字母表示。
N:批次大小,表示一个批次中的图像数量。
C:通道,表示一张图像中的通道数。
W:宽度,表示图像水平维度的像素数。
H:高度,表示图像垂直维度的像素数。

这四个字母的顺序表示像素数据如何存储在 1-d 内存空间中。例如,NCHW 表示像素数据首先以宽度存储,然后是高度、通道,最后是批量存储。使用通道优先索引从左到右访问数据。NCHW 是使用英特尔 MKL-DNN 的推荐数据布局,因为这种格式是 CPU 的高效数据布局。

TensorFlow 使用 NHWC 作为默认数据布局,但它也支持 NCHW。
在这里插入图片描述

英特尔 MKL-DNN 库通过矢量化利用 SIMD 指令,并通过多线程利用多个内核。矢量化技术有效利用了现代 CPU 的缓存和计算能力,以及指令集的效用。单个计算最多可处理 16 个单精度 (512 位长) 数字。同时,最多可以在一个周期内完成两次乘法和加法 (融合乘加 (FMA)) 运算。此外,多线程技术有助于同时执行多个独立运算。通过避免顺序执行,通常可以最好地执行深度学习任务的计算,因此获取并行运行的可用内核是加速深度学习任务的理想选择。英特尔 MKL-DNN 采用 OpenMP,以充分利用英特尔架构。

OpenMP* 线程绑定到不同内核的线程上下文并尽可能靠近,建议将此环境变量设置为可用的物理内核数。

Wordbook

Intel® Math Kernel Library for Deep Neural Networks (Intel® MKL-DNN)
Intel® Advanced Vector Extensions 2 (Intel® AVX2)
C/C++ Development Tools (CDT)

References

https://software.intel.com/content/www/cn/zh/develop/articles/maximize-tensorflow-performance-on-cpu-considerations-and-recommendations-for-inference.html


http://chatgpt.dhexx.cn/article/bdJh0OhC.shtml

相关文章

MKL学习——向量操作

前言 推荐两个比较好的教程: BLAS (Basic Linear Algebra Subprograms) LAPACK for Windows 命名规范 BLAS基本线性代数子程序的函数命令都有一定规范&#xff0c;便于记忆 <character> <name> <mod> () character 定义的是数据类型 s实数域&#…

mkl简介

一、概况 &#xff08;一&#xff09;下载 下载免费版本&#xff0c;注意保留serial number&#xff08;安装需要&#xff09; &#xff08;二&#xff09;安装 编辑silent.cfg 文件中的选项安装需要2G的空间&#xff0c;默认的tmp空间不足使用**–tmp_dir**指定 ./instal…

如何解决kaldi的依赖库mkl安装失败的问题

最近在学习如何使用kaldi进行语音识别。按照进程进行安装部署时发现Intel MKL库总是失败。 通过搜索大量的资料&#xff0c;但都发现不太适用。现在将失败的症状和解决方法分享一下&#xff0c;希望能给读者提供一些帮助。 通过执行 ./check_dependencies.sh 发现缺少Intel M…

oneKey mkl安装

1、oneKey mkl核心安装 进入官方下载地址&#xff0c;采用离线安装方式 1&#xff09;选择离线安装 2&#xff09;可以直接点击“download”下载安装包后再解压安装&#xff08;此种方式需要注册帐号&#xff0c;比较麻烦&#xff0c;介意选择下面的命令行安装&#xff09; …

Linux下MKL库的安装部署与使用,并利用cmake编译器调用MKL库去提升eigen库的计算速度

文章目录 前言一、MKL库的下载二、MKL库的安装与配置1.MKL库的安装与配置2.代码测试 总结 前言 在用C/C编写模型预测控制算法(MPC)的代码时候&#xff0c;由于预测步长和控制步长的设置较大&#xff0c;导致在利用eigen库进行矩阵计算的时候&#xff0c;矩阵n次幂计算时间过长&…

mysql 报1055错误_MySQL数据库报1055错误

有点坑啊&#xff0c;当初装MySQL数据库的时候没有整配置文件&#xff0c;结果MySQL报1055错误的时候&#xff0c;网上的解决办法都说如果需要永久生效的话&#xff0c;只能通过改配置文件实现&#xff0c;but&#xff0c;我没有配置文件&#xff0c;蜜汁尴尬啊 1、已安装的MyS…

mysql运行sql错误1055_sql数据库执行错误代码1055怎么解决?

展开全部 错误代码1055。不过看了Expression里面的原因描述,我基本知道怎么回事了。原因是因为62616964757a686964616fe59b9ee7ad9431333431373139mysql中对 group by 用法的规定。严格意义上说,就是group by之后。select 的字段只能是group by的字段。或者需要加聚合函数的。…

FOJ 1055

一&#xff0c;题目链接 http://acm.fzu.edu.cn/problem.php?pid1055 二&#xff0c;题目描述 三&#xff0c;题目分析 1.程序段的格式是已知的&#xff0c;一行为三个字符&#xff0c;且中间是赋值运算符&#xff0c;只需用一个数组记录字符是否 是已知的&#xff08;查表法…

MYSQL数据库报错 1055

MYSQL数据库报错 1055 今天在做毕业设计&#xff0c;当点开要查看的视图的时候&#xff0c;爆出了1055的错&#xff0c;该错误如下&#xff1a; 错误原因&#xff1a;在MySQL5.7之后&#xff0c;sql_mode中默认存在ONLY_FULL_GROUP_BY&#xff0c;SQL语句未通过ONLY_FULL_GRO…

leetcode1055

暴力查询即可&#xff0c;外面一层遍历target字符串&#xff0c;内层对source进行遍历&#xff0c;直到当前的内层遍历source中已无可匹配字符&#xff0c;在进行下一次source遍历&#xff0c;直到外层遍历结束。最终统计进行了几次内层遍历。 优化的方法&#xff1a;将内层遍历…

Mysql报错1055

Mysql group by报错 1055 [Err] 1055 Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column ‘xm_xhd.al.dy_uid’ which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_modeonly_full_…

MySQL 报错1055

一、问题描述 SELECT * FROM tbluser GROUP BY sex当我以这条语句进行数据库查询的时候&#xff0c;报了个错&#xff1a; > 1055 - Expression #1 of SELECT list is not in GROUP BY clause and contains nonaggregated column ceb.tbluser.uid which is not functiona…

mac mysql 1055_MySQL错误1055

问题描述:在MySQL数据库下,执行SQL插入语句报错。错误信息如下: 错误原因:在MySQL5.7之后,sql_mode中默认存在ONLY_FULL_GROUP_BY,SQL语句未通过ONLY_FULL_GROUP_BY语义检查所以报错。 ONLY_FULL_GROUP_BY:ONLY_FULL_GROUP_BY要求select语句中查询出来的列必须是明确的(…

MySQL 错误代码:1055 解决方案(推荐!!)

MySQL 错误代码:1055 解决办法 一、 MySQL版本二、 问题描述1. 问题描述2.ONLY_FULL_GROUP_BY-SQL示例 三、解决办法1.方法一2.方法二&#xff08;临时&#xff09;3.方法三&#xff08;永久&#xff09; 四、sql_mode常用值 一、 MySQL版本 MySQL版本&#xff1a;8.0.11 二、…

MySQL 出现1055错误 this is incompatible with sql mode=only full group by 的解决办法

文章目录 一、打开MySQL8.0 Command Line Client二、找到MySQL的my.ini文件路径三、修改my.ini里面的内容 前言 在学习过程中出现的问题&#xff1a;IDEA与Navicat出现不兼容的情况 会弹出1055的错误&#xff0c;这种错误通常在mysql 5.7以上的版本才会出现 1055 Expression #…

MySQL查询出现1055错误的解决方法

当SQL语句查询报1055错误时的解决方法 报错内容如下 报错原因 1.SQL语句中使用了group by&#xff0c;并且不需要分组的字段没有加上any_value()函数 2.MySQL数据库版本是大于5.7&#xff0c;报错信息中最后有一句sql_modeONLY_FULL_GROUP_BY&#xff0c;是因为MySQL数据库的…

1055 习题4-9-3 逆序输出正整数各位上数字

题目描述 输入一个不多于5位的正整数&#xff0c;按逆序输出各位上的数字&#xff0c;末尾换行。 注意&#xff1a;确保输入的正整数的位数不多于5。 输入 一个不多于5位的正整数。 输出 逆序输出各位上的数字&#xff0c;中间以空格分隔。 注意末尾的换行。 样例输入 2143 样…

IDEA破解后老是出现agent弹窗问题

第一步&#xff1a;在1这个路径下早到2这个文件 2.用解压软件提取2这个文件META-INF里面的important.txt放到上面1这个目录下&#xff08;这里使用的是7z解压&#xff09;

Intellij IDEA 破解方法和地址

IntelliJ IDEA是来自捷克的Jetbrains公司开发的Java开发工具(完爆Eclipse/MyEclipse)。有旗舰版和社区版两大版本&#xff0c;相对社区版而言旗舰版的功能更加丰富。官网提供了两个版本之间差异的详细比较。擅长企业级应用、移动应用以及Web应用开发。 支持MacOS,Windows7,Lin…

idea破解办法

在安装后启动的时候&#xff0c;Activate new license with选择License server&#xff0c;填上http://idea.iteblog.com/key.php&#xff0c;如图所示&#xff1a; 点击Activate&#xff0c;然后就搞定了。