PSCAD搭建的三相逆变器模型,看起来和CSDN另外一个三相逆变器模型差不多。
差别在于那个不能把有功/无功控制到指定值,而这个文件修正了里面的错误。
注意六个管子只有两个打开了interpolation(但基本不影响输出结果)。
下载后可以自己决定是否改为一致。
2025/5/21 2:53:16 193KB PSCAD 逆变器 三相 双环
1
【DM365_NAND启动模式解析】DM365是一款由TexasInstruments(TI)生产的数字媒体处理器,常用于视频处理和嵌入式系统。
在DM365中,NAND闪存是一种常见的非易失性存储器,用于存储固件和操作系统。
NAND启动模式是指DM365在上电或复位后从NAND闪存中加载启动代码的过程。
此过程涉及一系列复杂的步骤,确保系统能够正确地从NAND中读取和执行固件。
**NAND启动流程**1.**初始化**:系统首先初始化RAM1的高2KB栈空间(0x7800-0x7fff),避免覆盖用于存储UBL块号的最后32个字节(0x7ffc-0x8000)。
2.**禁止中断**:所有中断(IRQ和FIQ)被禁用,以确保启动过程不被打断。
3.**设置DEEPSLEEPZ/GIO0**:这个外部引脚在NAND启动时必须处于高电平。
4.**读取NANDID**:读取NAND闪存的设备ID,获取设备特性,如页面大小、块大小等。
5.**初始化NAND区域**:根据NAND的参数设置控制器和寄存器。
6.**搜索UBL描述符**:RBL(ROMBootloader)在block1的page0开始搜索UBL(UserBootLoader)的描述符。
如果未找到正确的UBL,会依次检查接下来的24个块,以防遇到坏块。
7.**处理UBL描述符**:UBL描述符包含入口点地址、占用的NAND页数、起始块和起始页等信息,用于指导UBL的加载和执行。
8.**ECC错误检测和校正**:开启硬件ECC(ErrorCorrectionCode)检测,复制UBL到IRAM(InternalRAM)。
如果检测到4位ECC错误,通过ECC算法进行纠正。
如果多次失败,RBL会尝试下一个块,直到找到有效的UBL描述符,或者在搜索完24个块后转而从SD卡启动。
9.**启动UBL**:在UBL的入口点执行代码,将控制权交给UBL。
10.**安全启动模式**:根据配置,启动模式可能包括PLL旁通模式,不使用快速EMIF、DMA或I-Cache。
在其他模式下,这些功能可以被启用以提高性能。
**NANDUBLdescriptor格式**UBL描述符是一个包含关键信息的数据结构,用于指示如何加载和执行UBL。
它可能包含如下字段:-入口点地址:UBL执行的起点。
-UBL占用的NAND页数:指示UBL的大小,必须是连续的页。
-UBL的起始块和起始页:定义UBL在NAND中的位置。
-MAGICIDs:特定的标识符,用于识别不同的启动模式。
**NAND启动详细流程**1.初始化栈空间、禁止中断、设置DEEPSLEEPZ/GIO0。
2.读取NAND设备ID,初始化NAND控制器。
3.搜索UBL描述符,最多遍历24个块。
4.复制并校验UBL到IRAM,根据UBL描述符配置启动选项。
5.转交控制权给UBL执行。
NAND启动流程图和具体的ARMNANDROMBootloader实例进一步详细说明了这个过程。
此外,支持的NAND设备ID列表确保了对多种NAND闪存设备的兼容性。
DM365的NAND启动模式解析涉及了设备识别、错误检测、固件加载和执行等多个环节,确保了系统的稳定和可靠启动。
理解这一过程对于开发和调试基于DM365的嵌入式系统至关重要。
2025/5/20 16:04:21 249KB DM365
1
###TIDM36x系列DSPNANDFlash启动过程详解####一、NANDFlash启动原理#####1.1DM365支持的NAND启动特性TI的TMS320DM365(以下简称DM365)多媒体处理芯片支持多种启动方式,包括NANDFlash启动。
在NANDFlash启动过程中,DM365具有一系列独特的启动特性:1.**不支持一次性全部固件下载启动**:DM365不支持一次性将所有固件数据从NANDFlash读入内存并启动,而是采用分阶段的方式。
首先从NANDFlash读取第二级启动代码(UserBootLoader,UBL)至ARM内存(ARMInternalMemory,AIM),然后执行UBL。
2.**支持最大4KB页大小的NAND**:支持的NANDFlash页大小可达4KB,这对于大多数常见的NANDFlash设备来说是足够的。
3.**支持特殊数字标志的错误检测**:在加载UBL时会进行错误检测,尝试最多24次在不同的block中寻找特殊数字标志,以确保数据的正确性。
4.**支持30KB大小的UBL**:DM365有32KB的内存用于存放启动代码,其中2KB用于RBL(ROMBootLoader)的堆栈,剩余的空间可用来存储UBL。
5.**用户可选的DMA与I-cache支持**:用户可以根据需要在RBL执行期间启用或禁用DMA和I-cache等功能。
6.**支持4位硬件ECC**:支持每512字节需要ECC位数小于或等于4位的NANDFlash,这有助于提高数据的可靠性。
7.**支持特定的NANDFlash类型**:支持那些需要片选信号在Tr读时间保持低电平的NANDFlash。
#####1.2NANDFlash启动流程NANDFlash启动流程是指从芯片上电到Linux操作系统启动的整个过程,主要包括以下几个步骤:1.**ROMBootLoader(RBL)阶段**:当DM365芯片上电或复位时,会根据BTSEL引脚的状态确定启动方式。
如果是NAND启动,则从ROM中的RBL开始执行。
RBL会初始化必要的硬件资源,如设置堆栈,关闭中断,并读取NANDFlash的ID信息以进行适当的配置。
2.**UserBootLoader(UBL)阶段**:RBL从NANDFlash读取UBL并将其复制到AIM中运行。
UBL负责进一步初始化硬件资源,如DDR内存,并为下一阶段准备环境。
3.**U-Boot阶段**:UBL从NANDFlash读取U-Boot并将其复制到DDR内存中运行。
U-Boot是完整的启动加载程序,它负责最终从NANDFlash读取Linux内核并将其复制到DDR内存中。
4.**Linux内核启动阶段**:U-Boot启动Linux内核,内核加载并运行,此时系统完成启动。
####二、NANDFlash启动的软件配合实现#####2.1UBL描述符的实现UBL描述符是UBL读取和执行的起点。
在NANDFlash中,UBL描述符通常位于特定的位置,包含UBL的起始地址和长度等信息。
RBL通过读取这些描述符来确定UBL的具体位置并加载到AIM中。
#####2.2U-Boot启动实现U-Boot是一种开源的启动加载程序,负责从NANDFlash读取Linux内核并将其加载到内存中。
U-Boot的实现依赖于UBL提供的环境,例如已经初始化的DDR内存。
#####2.3U-Boot更新UBL和U-Boot的原理U-Boot可以被用来更新UBL和自身的代码。
这一过程通常涉及到从NANDFlash读取新的代码版本,验证其完整性,并将其替换现有的UBL或U-Boot代码。
#####2.4NANDFlash没有坏块的情况在理想情况下,即NANDFlash没有坏块的情况下,启动流程会非常顺利。
RBL能够成功地从NANDFlash读取UBL,UBL也能正确地读取U-Boot,进而完成Linux内核的加载。
####三、结束语DM365的NANDFlash启动过程是一个复杂的多阶段过程,涉及ROMBootLoader(RBL)、UserBootLoader(UBL)和U-Boot等多个组件之间的协调工作。
通过对这些组件的理解和优化,可以有效地提高启动速度和系统的稳定性。
希望本文能帮助读者更好地理解DM365的NANDFlash启动过程及其背后的技术细节。
2025/5/20 15:59:25 439KB DSP NANDflash 启动过程分析
1
【TIDM365原版PCB_SCH】是一个与TexasInstruments(TI)的DM365芯片相关的项目,该项目包含的是原始的PCB(印制电路板)设计和SCH(电路原理图)文件。
这个设计是基于OrCAD软件进行的,这是一款广泛用于电子设计自动化(EDA)的专业工具,用于电路设计、仿真、布局和布线。
DM365是TI公司推出的一款基于DaVinci技术的数字媒体处理器,主要应用于高清视频处理和图像处理应用。
它集成了高性能的视频处理器和ARM9CPU,可以处理复杂的多媒体任务,如视频编码、解码、缩放、色彩转换等。
在开发基于DM365的产品时,理解其PCB和SCH设计至关重要,因为它们直接影响到系统的性能、可靠性和成本。
在OrCADDSN文件中,我们可以找到以下关键知识点:1.**电路原理图设计**:EVMDM365_Orcad_RevC.DSN是OrCAD的电路原理图文件,它包含了所有组件的电气连接关系。
工程师可以通过这个文件查看和分析DM365如何与其他组件交互,如电源管理、存储器、接口芯片等。
每个元件都用符号表示,并通过导线连接,展示信号流和电源路径。
2.**元器件库**:OrCAD提供了丰富的元器件库,包括了DM365在内的各种芯片及其引脚定义。
理解这些元器件的特性对于正确设计电路至关重要。
3.**信号完整性**:在设计PCB时,必须考虑信号完整性和电源完整性。
DM365的高速数据传输需要确保信号质量不受损失,这就需要精心设计PCB布线,避免串扰、反射等问题。
4.**热管理**:由于DM365在运行时可能会产生大量热量,所以PCB设计中会涉及到散热解决方案,比如使用散热片或热管,确保芯片不会过热。
5.**电源分配网络(PDN)**:强大的PDN设计能够提供稳定、低噪声的电源,对DM365这样的高性能处理器来说尤其重要。
PDN设计需要考虑电源层的布局、去耦电容的配置以及电源轨的分割。
6.**布局与布线**:OrCAD支持自动和手动布局布线,DM365的PCB设计需要考虑信号的敏感性,合理安排高频和低频元件的位置,优化布线路径以减少干扰。
7.**版本控制**:“RevC”可能表示这是设计的第三版,意味着可能经过了多次迭代和改进,每次修订可能解决了上一版存在的问题或者加入了新的功能。
8.**设计规则检查(DRC)**:在PCB设计完成后,OrCAD会执行DRC检查,确保设计符合制造工艺和电气规则,避免潜在的设计错误。
9.**仿真与验证**:OrCAD支持电路模拟和PCB设计前后的仿真,帮助工程师在制造之前预测并解决可能出现的问题。
这份"TIDM365原版PCB_SCH"资源对于开发者来说是一份宝贵的参考资料,它涵盖了从电路设计到物理实现的全过程,有助于深入理解DM365系统的工作原理和优化设计。
2025/5/20 13:24:27 353KB
1
《ICETEK-DM365-KBE-V3原理图详解》ICETEK-DM365-KBE-V3是一款由北京瑞泰公司推出的开发板,其设计基于DM365芯片,这款芯片是德州仪器(TexasInstruments,TI)生产的高性能数字媒体处理器,广泛应用于高清视频处理和多媒体应用领域。
本文将对ICETEK-DM365-KBE-V3的原理图进行详细解析。
DM365芯片的核心部分包括多个接口和信号线,如UART1(通用异步接收发送器)、I2C(Inter-IntegratedCircuit)总线、GPIO(GeneralPurposeInput/Output)引脚等。
UART1_RXD和UART1_TXD分别代表串行通信的接收和发送引脚,用于实现与外部设备的数据传输。
I2C_SDA和I2C_SCL则是I2C总线的时钟和数据线,用于控制和通信I2C兼容的外围设备。
在GPIO部分,我们可以看到EM_BA0到EM_A7等一系列引脚,它们可以作为通用输入输出使用,根据应用需求配置为输入或输出,以连接各种外设。
此外,还有SD1和SD0两个独立的SD卡接口,它们包含CLK(时钟)、CMD(命令)、D0至D3的数据线,用于支持存储扩展。
DM365还集成了McBSP(MultichannelBufferedSerialPort)接口,这是TI的多通道缓冲串行端口,用于音频和语音数据传输。
McBSP_FSR、McBSP_CLKR、McBSP_DR等引脚构成接收通道,而McBSP_FSX、McBSP_CLKX、McBSP_DX则构成发送通道,提供灵活的音频接口能力。
此外,DM365开发板上还包括了以太网PHY(物理层)接口,如TX_EN、TX_CLK、TX_D0至TX_D3、RX_D0至RX_D3等,这些接口负责处理以太网的物理层传输,确保网络数据的稳定传输。
同时,PHY接口还包含了RX_CLK、RX_DV、RX_ER等,用于接收端的数据同步和错误检测。
电源管理方面,开发板上有多个电压等级的电源引脚,如VCC_5V、VCC_3.3V、VCC_1V8等,以满足不同组件的供电需求。
同时,电路中还包含了电容C12、C18、C15、C27等,用于滤波和稳定电压。
开发板上还提供了多种视频输入和输出接口,如VIDEO_IN、VIDEO3S、VIDEO4,以及相关的同步信号如VOUT_HSYNC、VOUT_VSYNC、VOUT_LCD_OE、VOUT_VCLK等,支持不同的视频源和显示设备。
此外,还有音频接口如DAC_1_G、DAC_2_B、DAC_3_R,以及麦克风输入MIPI_CSI,满足多媒体应用的需求。
ICETEK-DM365-KBE-V3开发板具有丰富的接口和功能,集成了DM365芯片的多媒体处理能力,为开发者提供了强大的硬件平台,适用于高清视频处理、音频处理、网络通信等多种应用场景。
通过深入理解其原理图,开发者可以更好地利用该开发板进行产品设计和开发。
2025/5/20 8:13:33 53KB DM365
1
MinGW-W64GCC-8.1.0是针对Windows平台的一个开源的GCC(GNUCompilerCollection)版本,专为64位和32位应用程序的开发设计。
GCC是一套广泛使用的编程语言编译器,包括C、C++、Objective-C、Fortran、Ada和Go等。
MinGW-W64是对原始MinGW的扩展,增加了对64位Windows操作系统的支持,而MinGW仅支持32位。
在VSCode(VisualStudioCode)这样的集成开发环境中,配置并使用GCC编译器是提升开发效率的重要步骤。
MinGW-W64GCC-8.1.0提供了与VSCode配合的编译环境,使得开发者能够在VSCode内直接编写、编译和运行C/C++代码,无需离开IDE。
安装mingw-w64-install.exe这个执行文件,会帮助用户在本地系统上安装所需的编译工具链,包括g++(C++编译器)和gcc(C编译器)。
在安装过程中,你需要选择合适的架构(x86_64for64-bit或i686for32-bit)以及安装目录。
安装完成后,你需要将MinGW-W64的bin目录添加到系统环境变量PATH中,以便于在任何位置调用gcc和g++命令。
使用VSCode编译GCC项目,首先需要安装C/C++插件。
然后,在项目根目录下创建一个名为`tasks.json`的文件,定义编译任务。
例如,对于一个简单的C++程序,`tasks.json`可能如下:```json{"version":"2.0.0","tasks":[{"label":"build","type":"shell","command":"g++","args":["-g",//添加调试信息"${file}",//当前打开的文件"-o","${fileDirname}\\${fileBasenameNoExtension}.exe"//输出可执行文件],"problemMatcher":["$gcc"]}]}```接下来,通过按`Ctrl+Shift+B`或点击左侧活动栏的任务图标,VSCode会自动识别并运行这个编译任务。
如果一切配置正确,你的C/C++程序就能顺利编译并通过VSCode的内置终端运行。
此外,为了调试代码,你还需要在`.vscode`目录下创建一个`launch.json`文件,设置调试配置。
例如,对于C++程序,你可以这样配置:```json{"version":"0.2.0","configurations":[{"name":"GDB调试","type":"cppdbg","request":"launch","program":"${workspaceFolder}/${fileBasenameNoExtension}.exe","args":[],"stopAtEntry":false,"cwd":"${workspaceFolder}","externalConsole":false,"MIMode":"gdb","miDebuggerPath":"gdb.exe","setupCommands":[{"description":"启用C++的自动完成","text":"-enable-pretty-printing","ignoreFailures":true}]}]}```通过这些步骤,你就可以在VSCode中愉快地使用MinGW-W64GCC-8.1.0进行C/C++的开发工作了。
记得保持GCC的更新,以获取最新的语言特性支持和错误修复。
同时,熟悉VSCode的其他功能,如代码自动完成、代码格式化和版本控制集成,将有助于提升开发效率。
2025/5/10 15:36:36 918KB gcc编译 vscode编译gcc
1
格式:PDG作者:邓华出版社:人民邮电出版社出版日期:2003-09-01内容简介本书着重介绍了MATLAB在通信仿真,尤其是移动通信仿真中的应用,通过丰富具体的实例来加深读者对通信系统仿真的理解和掌握。
全书共分10章,前3章介绍MATLAB通信仿真的基础,包括Simulink和S-函数;
第4~8章分别介绍了信源和信宿、信道传输、信源编码、信道编码、信号交织以及信号调制的仿真模块及其仿真实现过程;
第9章介绍了在通信系统的仿真和调试过程中经常遇到的问题及其解决办法;
最后,第10章以cdma2000为例介绍了移动通信系统的设计和仿真。
本书适用于通信行业的大专院校学生和研究人员,既可以作为初学者的入门教材,也可以用作中高级读者和研究人员的速查手册。
第1章MATLAB与通信仿真11.1MATLAB简介11.1.1MATLAB集成开发环境21.1.2MATLAB编程语言61.2通信仿真81.2.1通信仿真的概念81.2.2通信仿真的一般步骤9第2章Simulink入门122.1Simulink简介122.2Simulink工作环境132.2.1Simulink模型库132.2.2设计仿真模型142.2.3运行仿真142.2.4建立子系统152.2.5封装子系统172.3Simulink模型库20第3章S-函数233.1S-函数简介233.1.1S-函数的工作原理233.1.2S-函数基本概念243.2M文件S-函数263.2.1M文件S-函数简介263.2.2M文件S-函数的编写示例303.3C语言S-函数463.3.1C语言S-函数简介463.3.2C语言S-函数的编写示例513.4C++语言S-函数60第4章信源和信宿664.1信源664.1.1压控振荡器664.1.2从文件中读取数据684.1.3数据源724.1.4噪声源784.1.5序列生成器854.1.6实例4.1--通过压控振荡器实现BFSK调制994.2信宿1014.2.1示波器1014.2.2错误率统计1034.2.3将结果输出到文件1054.2.4眼图、发散图和轨迹图108第5章信道1165.1加性高斯白噪声信道1165.1.1函数awgn()1165.1.2函数wgn()1185.1.3加性高斯白噪声信道模块1205.1.4实例5.1--BFSK在高斯白噪声信道中的传输性能1225.2二进制对称信道1275.2.1二进制对称信道模块1275.2.2实例5.2--卷积编码器在二进制对称信道中的性能1285.3多径瑞利衰落信道1325.3.1多径瑞利衰落信道模块1325.3.2实例5.3--BFSK在多径瑞利衰落信道中的传输性能1345.4伦琴衰落信道1385.4.1伦琴衰落信道模块1385.4.2实例5.4——BFSK在多径瑞利衰落信道中的传输性能1395.5射频损耗1425.5.1自由空间路径损耗模块1425.5.2接收机热噪声模块1445.5.3相位噪声模块1455.5.4相位/频率偏移模块1465.5.5I/Q支路失衡模块1485.5.6无记忆非线性模块149第6章信源编码1536.1压缩和扩展1536.1.1A律压缩模块1536.1.2A律扩展模块1546.1.3μ律压缩模块1556.1.4μ律扩展模块1566.2量化和编码1576.2.1抽样量化编码器1576.2.2触发式量化编码器1586.2.3量化解码器1596.2.4实例6.1--A律十三折与μ律十五折的量化误差1596.3差分编码1626.3.1差分编码器1626.3.2差分解码器1636.4DPCM编码和解码1646.4.1DPCM编码器1646.4.2DPCM解码器1666.4.3实例6.2--DPCM与PCM系统的量化噪声166第7章信道编码和交织1727.1分组编码1727.1.1二进制线性码1727.1.2二进制循环码1747.1.3BCH码176
2025/5/8 14:23:11 23.47MB matlab pdg
1
围住神经猫代码完整可以用,网上下载的,修正了错误,只供学习用。
2025/5/7 17:15:26 1.53MB 神经猫 安卓
1
基于DimaWebApp的可观察性和测试研讨会免责声明此应用程序几乎没有内置安全性,因此如果不运行并打开互联网,则可能会面临风险,而您自己承担风险就运行该应用程序。
执照该应用程序在下运行,您也可以阅读更多信息。
欢迎来到迪马Dima应用程序是一个Web应用程序,具有围绕图像的基本功能。
该存储库的主要目的是为软件专业人员提供一个游乐场,以练习他们对软件应用程序的调试和检测,以提高可观察性。
因此,最小的DimaWebApp意味着可以行使超能力的遥测堆栈。
总是会发现错误和问题。
有些是计划好的,有些是有趣的巧合。
如果您在找不到任何内容,请创建请求请求,我们很乐意为您提供信息。
2025/5/6 20:58:49 21.46MB microservices workshop monitoring logging
1
资源里是我们算法分析与设计课程的ppt以及我整理的ppt里的错误
2025/5/5 7:53:23 4.59MB 哈工大 软件学院
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡