MATLAB分布式数组与codistributed数组详解

下载需积分: 50 | PDF格式 | 433KB | 更新于2024-08-09 | 194 浏览量 | 18 下载量 举报
收藏
"分布式数组-xds100v3调试器原理图完整版" 在MATLAB中,分布式数组和codistributed数组是并行计算的重要概念,它们允许用户利用多核计算平台提升运算效率。MATLAB并行计算工具包提供了对这两种数组类型的支持,以实现数据并行编程。 分布式数组是MATLAB客户端创建的一种数据结构,其数据分布在开放的MATLAB池(lab)中的一维上,通常是沿着最后非单独维度。这种分布是自动且均匀的,用户在创建时无法直接控制分布细节。分布式数组可以在spmd语句内部作为codistributed数组访问,而在spmd语句外部则作为普通的分布式数组使用。 创建分布式数组有三种方法: 1. 使用`distributed`函数将已存在的数组分配到lab中。 2. 调用过载的分布式对象函数(如`distributed.eye`、`distributed.rand`等)直接在lab上创建分布式数组,无需预先在lab中存在该数组。 3. 在spmd语句中创建codistributed数组,然后在spmd外部以分布式数组的形式访问,这允许使用自定义的分布策略。 codistributed数组与分布式数组的主要区别在于,它们是在lab之间被分割的,通常与执行代码的lab相同。在spmd语句中,可以创建codistributed数组,并且可以在客户端以分布式数组的形式访问,这提供了从不同位置访问相同数组数据的能力。 MATLAB并行计算工具包中的`parfor`循环是数据并行编程的核心,它允许将循环任务分解到多个核心上并行执行。与传统的`for`循环相比,`parfor`可以显著提高计算效率,但需要注意的是,`parfor`的使用场景需满足可并行化条件,比如循环体内的计算独立且不依赖于循环变量的顺序。 在使用`parfor`时,需要注意以下几点: - MATLAB路径应保持一致,避免因路径不同导致的运行问题。 - 错误处理需要特别考虑,因为并行任务可能会同时抛出错误。 - 存在某些限制,比如循环体不能包含递归或对全局变量的修改。 - 性能优化是关键,避免不必要的数据传输和同步操作。 - 老版本的MATLAB可能不支持所有新特性,确保兼容性。 此外,`spmd`(Single Program, Multiple Data)结构用于任务并行编程,它允许在多个lab间同步执行相同的代码段。`spmd`的使用包括: - 在需要所有lab执行相同代码但可能产生不同结果时使用。 - 通过`matlabpool`创建并管理MATLAB资源。 - 定义`spmd`语句,使lab间可以独立处理数据。 - 使用`composite`对象在lab间共享数据,确保数据的持久性和次序。 在spmd语句中,`composite`对象用于在lab间传递和访问数据,而不在spmd外部创建的`composite`则仅在创建它的lab内可见。分布式数组和`composite`的结合使用,可以实现更灵活的数据分布和通信策略,从而充分利用多核计算资源。

相关推荐

filetype
首先介绍一下XDS100v2的功能: XDS100V2 仿真器是XDS100 仿真器的第二个版本,支持 TI 的各种芯片调试。支持USB2.0 高速接口,通过14PIN 的接口进行仿真调试,支持Code Composer Studio(CCS)V4 和更高的版本。可用于 Windows 2000、XP、Vista 等操作系统。 XDS100v2 Features -All of the XDS100 General Features -支持USB2.0 高速接口 -Support targets with 14-pin TI JTAG connector or 20-pin TI JTAG connector as used by Texas Instruments embedded processors. -支持多种处理器: TMS320C28x, TMS320C54x, TMS320C55x, TMS320C64x+, TMS320C674x, TMS320C66x, ARM 9, ARM Cortex R4, ARM Cortex A8, ARM Cortex A9 and Cortex M3 (requires CCSv4.2.2 or later). -Supports cable-break detection -支持断电检测 -Support for multiple FTDI devices -支持自适应时钟 -LED light to indicate active USB connection -支持Code Composer Studio v4 和更高版本 (不支持 Code Composer Studio v3.3) 从介绍看出,v2功能还是挺强大的,对于入门学习来说是一个很好的选择~ 这是我的板子,跟TI的公版没大的区别,改动了供电部分,使用了廉价的1117-3.3,FT2232H的晶振改成了直插的,USB口改成了方形。整个仿真器主要芯片有FT2232H、赛灵思CPLD XC2C32A 、EEPROM IS93C46D这个是必须自己买的。FT2232H是一个接口芯片,它可以实现USB到两个串行UART、FIFO、Bit-Bang IO接口,并且还可以配成MPSSE,I2C,JTAG及SPI总线。外挂EEPROM,用于IO配置及储存USB VID和PID。 TPD2E001——用于高速数据接口的低电容 2 通道 +/-15KV ESD 保护阵列,用来保护USB信号 TPD4E002——具有 +/-15kV ESD 保护的四路低电容阵列,用来保护JTAG信号 OPA2363——具有关断状态的 1.8V、高 CMR、RRIO 运算放大器 这3个芯片都是TI自己家的,有条件可以向TI申请。其他的就是些电阻电容接插件了。需要注意的是FTDI的芯片比较贵,市场也有假货;生产93C46的厂家很多,而且93C46好像有几个版本还不一样,我买过CSI93C46S焊上去用不成,后来换了AT93C46就好了,尽量买后缀为D的版本。TPD2E001、TPD4E002个头比较小,焊的时候需要注意一下~我画的原理图和PCB也都在附件里。板子焊好之后,插上USB,应该会提示发现新硬件,会多出来两个虚拟串口。
1158 浏览量