现在的技术,还是一个线程只能运行在一个 CPU 上。多核心,必须用多线程/进程来运行才能实现最大化。当然,你可以单个线程不停的在所有的 CPU 上来回跳。但是效率会很低很低。
因为 CPU 有寄存器和缓存的问题。如果你切换 CPU 运行,所有的数据都要进行一次传递。非常浪费时钟(在 CPU 上,程序执行不是一个时钟马上就能任意执行一个指令,而是流水线作业,一个指令需要很多个时钟才能处理完,数据存取也都要等)。
这也因为程序原本就都是顺序执行的。你没办法让一个程序的后面的结果可以跳过前面的结果而得出。
大多数软件都是适合在单核下工作,支持多核的软件一般都是比较大型的,运算量比较高的。
具体你可以打开任务管理器,如果运行某程序,某个核心的使用率相当高,其他核心处于很低的水平,就说明该软件是单核心的了;如果某程序一运行,几个核心比较平均的增加了很多使用率,说明该软件是支持多核的!
支持多核的软件可以充分利用CPU
根据摩尔定律,芯片上晶体管的数目每隔18~24个月就会翻一番。如同在过去40年里一样,这个定律现在还是正确的,但是在性能上却并不再呈现一个线性增强的现象。以前,芯片制造商通过提高处理器时钟速度使芯片性能翻番――从100MHz到200MHz,直至近来达到吉赫兹。
然而如今,因为能量消耗和热量发散的限制,通过增加时钟速度来提高性能已经不再可行。芯片制造商开始转向全新的芯片结构,即一个芯片上有多个处理器核。相对于单核,采用多核处理器的程序员们可以完成更多全局工作。然而,要充分利用多核处理器的优点,程序员们必须重新考虑他们该如何开发应用程序。有些程序员,希望在终端客户将他们的电脑简单升级到快速处理器的时候,就能立即获得软件应用程序性能的增强。按照微软的软件工程师HerbSutter的话来说,对这些程序员“已经没有免费的午餐”。简而言之,如今程序员们应当致力于可持续的性能改进。
提高处理器时钟速度,则顺序程序的性能改进;为电脑升级一个更快速的CPU,意味着每一条独立指令的运行速度都会加快。要想使用多核系统以继续提高性能,开发者需要设计应用程序,为每个核分配工作――本质上即是开发一个并行应用程序来取代顺序应用程序。
幸运的是,NI LabVIEW软件非常适合于工程师和科学家们充分利用多核芯片的处理能力,主要原因有下面三个。
1LabVIEW是一种图形化数据流编程语言
开发者可在LabVIEW中简便地实现并行任务,使得开发新的应用程序并更改现存的应用程序以利用多核处理器的优点成为可能。LabVIEW从50版本开始就是多线程的,而现在的85版本更引进了新的功能,以利用多核处理器的优点。
2LabVIEW将多核性能引进嵌入式实时硬件中
LabVIEW 85将桌面 *** 作系统(例如Windows和Linux)的自动多任务处理功能――也就是对称多处理技术(SMP)――引入确定性的实时系统。
3LabVIEW处于“Multicore―Ready”软件层次的顶层
LabVIEW应用程序的每一层(例如:LabVIEW应用程序代码、低层函数、I/O驱动),都是线程安全的,它们可以利用多核处理器的优点。
LabVIEW是一种图形化数据流编程语言
使用LabVIEW开发应用程序的最主要好处就是其直观的、图形化的语言。在LabVIEW中,解决工程问题就如同在纸上画方块图一样简单。由于LabVIEW能够并行表达和执行任务,所以现代的多核处理器使得LabVIEW成为编程工具的一个更有利的选择。
LabVIEW的数据流特性意味着不论何时,只要代码在线上有个分支或在方块图上有个并行序列,潜在的LabVIEW编译器就会尝试并行执行代码。用计算机科学的专有名词来说,这就是“隐并行”,因为你并不需要为了并行执行程序而明确编写代码,LabVIEW的图形化语言将自行实现一定程度的并行性。
从单核到双核计算机,理论上的优势是性能的双倍改进。但是,如何逼近该极限,则与你能多大程度上并行执行程序有关。LabVIEW程序员自然是并行地编写其算法。在普通LabVIEW应用程序的初始基准下,若不考虑多核编程技术,不改变代码,则其性能能够提高15%~20%。
图1是一个简单的应用例子:LabVIEW代码的一个分支用于两个分析任务――滤波 *** 作和快速傅里叶变换(FFT)――在双核机器上并行执行。因为两个任务计算量都很大,所以采用双核执行,相对于单核的效率改进是1省略/multicore上找到所有这些优化方案的例子。
LablVEW为实时嵌入式硬件引入多核性能
一直以来,工程师们使用的工具都不能利用嵌入式多核系统的特性进行最优化的并行式编程。LabVIEW 85软件为确定性实时系统引入了台式机的自动多线程调度器(也被称为SMP)。LabVIEW 85的实时模块加入了一流的多核系统支持,它有着如下特性:
在嵌入式实时系统中,在多个核上自动进行负载均衡。
对于时间关键(time-critical)的代码,可以将定时循环分配到指定的处理器上将定时循环结构中的关键代码与应用程序中的其他代码隔离开。
利用Real-Time ExecutionTrace Toolkit 20工具,用户可以方便地对VI程序运行过程中的线程和处理器核进行图形化的表示,以便更好地调整实时系统,进而获得最佳性能。
LabVIEW处于“Multicore-Ready”软件层次的顶层
Intel公司定义了用户需要评估的四层软件层次来确定多核系统的可用程度。这四层软件层次分别是 *** 作系统、设备驱动、应用程序库和开发工具。如果所用的应用程序库和设备驱动不是为多核而设计的,或者 *** 作系统不能够在多个核上进行负载均衡,那么并行化程序在多核系统上是不能够运行得更快的。
设备驱动软件层的一个例子就是NI-DAQmx驱动软件。传统的NI-DAQ是“线程安全”的,也就是说在一个NI-DAQ函数被调用时,整个程序库会阻塞其他调用的线程。从第一感觉看来,这是非常有逻辑性的,因为NI-DAQ是用来控制硬件的,而硬件通常被认为是单一的源。NI-DAQmx这款重新设计过的新型DAQ驱动程序是可重入的,这意味着多个DAQ任务可以以一种真正并行的方式运行而不再需要阻塞线程。利用这种方法,驱动程序可以使用户的应用程序在同一块电路板上并行地运行多个任务,诸如独立的模拟和数字输入/输出等。
LabVIEW――理想的并行化编程语言
大多数用户将会看到多核系统所带来的好处,它利用改进的性能同时运行多个应用程序(电子邮件、视频、文字处理等),这也被称为多任务。但是,对于试图对单一应用程序进行优化的开发者而言,它所能提供的好处是有限的。
工程师和科学家们正在为测试需要或者在控制应用中改进的闭环速率而寻找更快的测量仪器。他们需要考虑如何实现并行的应用。LabVIEW软件就是这样一种用户可以借助于它所提供的软件环境来实现并行应用的有效工具。语言的数据流特性、LabVIEW Real-Time工具对嵌入式平台开发的多核支持,以及自上而下的为多核而设计的软件层,使得LabVIEW软件成为进行并行化编程的首选。
1 在BIOS中启用多核多线程功能,一般在“高级”或“性能”菜单中可以找到。
2 安装支持多核多线程的 *** 作系统,如Windows 7/8/10、Linux或Mac OS X。
3 安装最新的BIOS固件,以便获得最新的特性和功能。
4 安装最新的驱动程序,以便获得最新的特性和功能。
5 使用支持多核多线程的应用软件,如Adobe Photoshop、Adobe Premiere Pro、Autodesk Maya、Autodesk 3ds Max、Microsoft Office Suite、Google Chrome浏览器或其它应用软件。
以上就是关于fcpx是否支持多核多线程全部的内容,包括:fcpx是否支持多核多线程、什么应用程序对CPU的单核心性能要求高、多核处理器 LabVIEW 8.5为开发者带来多核处理器的强大功能等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)