针对高光谱图像特征利用不足和训练样本难以获取的问题,提出了一种具有多特征和改进堆栈稀疏自编码网络的高光谱图像分类算法。
采用流形学习获得高光谱图像的低维数据结构,并提取高光谱图像的光谱特征、具有空间信息的局部二值模式(LBP)特征及拓展多属性剖面(EMAP)特征。
利用主动学习查询特征性强的未标记样本并将其标记,利用融合空谱联合信息的样本训练堆栈主动稀疏自编码神经网络并用Softmax分类器对其分类。
Indianpines数据集的总体分类精度达到98.14%,PaviaU数据集总体分类精度达到97.24%。
实验结果表明,该算法分类精度高,边界点分类效果更好。
2025/6/29 4:53:23 12.88MB 图像处理 高光谱图 多特征 流形学习
1
本教材介绍了五个方面的内容:MOS器件基本原理以及主要的特性,VLSI中逻辑结构的主要设计方法,用于VLSI系统的模拟集成单元设计方法,VLSI的测试问题与相关技术,VLSI设计系统及其组成。
涉及了五个方面的基础知识:MOS器件基础知识,半导体工艺基础知识,集成电路版图基础知识,逻辑、电路设计基础知识和CAD基础知识。
《VLSI设计基础》作为VLSI设计基础教材,注重相关理论的结论和知识的应用。
可作为本科生教材和研究生参考书。
第1章VLSI设计基础概述1.1VLSI设计技术基础与主流制造技术1.2VLSI设计方法与设计技术1.3新技术对VLSI的贡献1.4ASIC和VLSI1.5SOC1.6VLSI的版图结构和设计技术1.6.1VLSI的版图总体结构1.6.2VLSI版图的内部结构第2章MOS器件与工艺基础2.1MOS晶体管基础2.1.1MOS晶体管结构及基本工作原理2.1.2MOS晶体管的阈值电压VT2.1.3MOS晶体管的电流-电压方程2.1.4MOS晶体管的平方律转移特性2.1.5MOS晶体管的跨导gm2.1.6MOS晶体管的直流导通电阻2.1.7MOS晶体管的交流电阻2.1.8MOS晶体管的最高工作频率2.1.9MOS晶体管的衬底偏置效应2.1.10CMOS结构2.2CMOS逻辑部件2.2.1CMOS倒相器设计2.2.2CMOS与非门和或非门的结构及其等效倒相器设计方法2.2.3其他CMOS逻辑门2.2.4D触发器2.2.5内部信号的分布式驱动结构2.3MOS集成电路工艺基础2.3.1基本的集成电路加工工艺2.3.2CMOS工艺的主要流程2.3.3Bi-CMOS工艺技术第3章工艺与设计接口3.1工艺对设计的制约与工艺抽象3.1.1工艺对设计的制约3.1.2工艺抽象3.2设计规则3.2.1几何设计规则3.2.2电学设计规则3.2.3设计规则在VLSI设计中的应用第4章晶体管规则阵列设计技术4.1晶体管阵列及其逻辑设计应用4.1.1全NMOS结构ROM4.1.2ROM版图4.2MOS晶体管开关逻辑4.2.1开关逻辑4.2.2棒状图4.3PLA及其拓展结构4.3.1“与非-与非”阵列结构4.3.2“或非-或非”阵列结构4.3.3多级门阵列(MGA)4.4门阵列4.4.1门阵列单元4.4.2整体结构设计准则4.4.3门阵列在VLSI设计中的应用形式4.5晶体管规则阵列设计技术应用第5章单元库设计技术5.1单元库概念5.2标准单元设计技术5.2.1标准单元描述5.2.2标准单元库设计5.2.3输入、输出单元(I/OPAD)5.3积木块设计技术5.4单元库技术的拓展第6章微处理器6.1系统结构概述6.2微处理器单元设计6.2.1控制器单元6.2.2算术逻辑单元(ALU)6.2.3乘法器6.2.4移位器6.2.5寄存器6.2.6堆栈6.3存储器组织6.3.1存储器组织结构6.3.2行译码器结构6.3.3列选择电路结构第7章测试技术和可测试性设计7.1VLSI可测试性的重要性7.2测试基础7.2.1内部节点测试方法的测试思想7.2.2故障模型7.2.3可测试性分析7.2.4测试矢量生成7.3可测试性设计7.3.1分块测试7.3.2可测试性的改善设计7.3.3内建自测试技术7.3.4扫描测试技术第8章模拟单元与变换电路8.1模拟集成电路中的基本元件8.1.1电阻8.1.2电容8.2基本偏置电路8.2.1电流偏置电路8.2.2电压偏置电路8.3放大电路8.3.1单级倒相放大器8.3.2差分放大器8.3.3源极跟随器8.3.4MOS输出放大器8.4运算放大器8.4.1两级CMOS运放8.4.2CMOS共源-共栅(cascode)运放8.4.3带有推挽输出级的运放8.4.4采用衬底晶体管输出级的运放8.5电压比较器8.5.1电压比较器的电压传输特性8.5.2差分电压比较器8.5.3两级电压比较器8.6D/A、A/D变换电路8.6.1D/A变换电路8.6.2A/D变换电路8.
2025/6/24 15:01:24 12.57MB VLSI
1

**正文**《ADS工具入门教程》ADS,全称Arm Development Studio,是Arm公司推出的一款强大的嵌入式系统开发和调试工具。
它为基于Arm架构的芯片提供了全面的软件开发支持,包括C/C++编译器、调试器、性能分析器等功能。
本教程将引导您了解如何使用ADS进行高效的开发工作。
一、ADS安装与配置下载并安装ADS软件,确保您的计算机满足其系统需求。
安装完成后,启动ADS,进行必要的环境配置,包括设置编译器路径、目标硬件配置以及工程模板等。
这一步对于确保项目能够正确构建和链接至关重要。
二、创建新工程在ADS中,新建一个工程是开始项目的第一步。
通过“File”菜单选择“New Project”,然后按照向导提示选择合适的工程类型(如应用或库项目),设置工程名称和位置。
接着,指定要使用的处理器型号,这会影响到编译器的配置和产生的代码目标架构。
三、添加源代码在新创建的工程中,可以添加源代码文件(.c或.c++)和头文件(.h)。
通过“Project”菜单的“Add Files to Group”选项,选择要包含的文件。
记得将源代码组织到适当的文件夹结构中,以便于管理和维护。
四、编译与链接完成代码添加后,可以进行编译和链接操作。
点击“Build”菜单的“Build Project”或使用快捷键,ADS会自动执行预处理、编译、汇编和链接的步骤。
如果出现错误,ADS会提供详细的错误报告,帮助定位问题。
五、调试设置ADS的强大之处在于其调试功能。
在工程属性中,配置调试器设置,如GDB服务器端口、目标设备连接方式等。
设置完后,可以在源代码中设置断点,使用“Debug”菜单的“Start Debugging”启动调试会话。
在调试过程中,可以查看变量值、单步执行、调用堆栈和内存查看等功能。
六、性能分析除了基本的开发和调试,ADS还提供了性能分析工具。
通过配置性能分析器,可以收集CPU使用率、指令执行统计等数据,帮助优化代码性能。
在分析结果中,可以找到程序的瓶颈,指导优化工作。
七、示例解析在本教程的压缩包文件"ads_tutorial"中,包含了使用ADS进行开发的实例项目。
这些示例覆盖了从简单的Hello World程序到复杂功能的实现,详细展示了ADS的各个功能。
通过对这些示例的学习和实践,您可以更深入地理解ADS的工作流程和使用技巧。
总结,ADS作为一款强大的嵌入式开发工具,不仅提供了完整的开发环境,还包括了丰富的调试和分析功能。
通过本教程的学习,您将能够熟练掌握ADS的基本操作,并利用它来开发高效、可靠的Arm架构嵌入式系统。
记得结合实际项目不断练习,提升自己的开发技能。
2025/6/15 22:25:19 294KB
1
简介:
### 开发51单片机操作系统时应注意的问题#### 一、引言随着嵌入式系统的广泛应用,针对特定硬件平台的操作系统开发变得尤为重要。
51单片机作为一款经典的微控制器,在工业控制、家用电器等领域有着广泛的应用。
然而,由于其硬件资源的限制,在51单片机上开发操作系统面临诸多挑战。
本文将详细介绍开发51单片机操作系统时需要注意的关键问题。
#### 二、关键问题详解##### 1. 操作系统软件的代码长度控制51系列单片机由于硬件资源的限制(如ROM空间较小),因此对于操作系统代码的大小有严格的要求。
通常情况下,一个基于51单片机的应用程序大约需要7至8KB的ROM空间。
相比之下,如果操作系统本身就需要几十KB的空间,那么留给用户应用程序的空间将非常有限,这显然不利于实际应用。
例如,流行的嵌入式操作系统往往体积较大,无法适用于51单片机。
为了克服这一限制,开发者需要采取以下措施:- **精简设计**:简化操作系统的功能模块,确保核心功能的同时尽可能减小代码量。
- **模块化**:采用模块化设计,允许用户根据具体需求选择加载必要的模块,从而降低整体代码量。
- **代码优化**:通过高效的编码技巧来减少代码长度,比如使用更简洁的数据结构和算法。
##### 2. 控制操作系统对片内RAM的占用51系列单片机仅有128或256字节的片内RAM空间,这对于运行操作系统而言是非常有限的。
如果操作系统占用过多的RAM空间,将严重影响用户应用程序的正常运行。
因此,开发者需要特别注意以下几点:- **最小化RAM使用**:减少操作系统的RAM占用,确保有足够的空间供用户应用程序使用。
- **合理分配资源**:优化RAM的使用方式,避免不必要的资源浪费。
- **外部RAM利用**:在不影响性能的前提下,考虑将部分数据存储在外置RAM中,以减轻内部RAM的压力。
##### 3. 解决函数的重入问题对于实时占先式操作系统而言,函数的重入性至关重要。
重入函数能够在不破坏数据的情况下被多个任务调用。
要实现函数的重入性,必须满足以下条件之一:- **不使用共享资源**:确保函数内部没有依赖任何共享资源。
- **使用中断禁用**:在使用共享资源时暂时禁用中断,以保证数据的一致性。
- **信号量机制**:通过申请和释放信号量来管理对共享资源的访问。
在标准C中实现这些条件相对简单,但在Keil C51编译器环境下,由于局部变量的静态分配特性,实现起来较为复杂。
开发者可以通过以下策略应对这一挑战:- **手动管理资源**:显式地控制共享资源的访问,避免自动管理带来的不确定性。
- **代码审查**:仔细检查函数中的资源使用情况,确保符合重入性的要求。
- **测试验证**:通过严格的测试来验证函数的重入性,确保其在多任务环境下的正确运行。
##### 4. 堆栈的分配与管理在占先式操作系统中,任务之间的切换频繁发生,因此需要合理分配和管理堆栈空间。
每个任务都需要有自己的堆栈,用于保存任务状态信息。
由于51单片机的RAM空间有限,堆栈的分配策略成为了一项重要的考量因素。
- **按需分配**:根据任务的实际需求动态分配堆栈空间,避免过度预分配造成的资源浪费。
- **优化堆栈使用**:通过调整任务的设计和编码方式来减少堆栈的需求。
- **复用机制**:探索堆栈空间的复用机制,如在任务间共享堆栈空间等方法。
#### 三、结论开发51单片机操作系统是一项充满挑战的任务,需要开发者在有限的硬件资源下,精心设计并优化操作系统的各个方面。
通过本文所述的关键问题及解决方案的探讨,希望能够帮助开发者更好地理解和应对这些挑战,成功开发出高效、可靠的51单片机操作系统。
2025/6/15 19:58:32 63KB
1
InfluxData.Net与InfluxDBv1.3.x和Kapacitorv1.0.0API兼容注意:该库很可能也可以与更新版本的TICK堆栈一样好,但是尚未针对它们进行过测试。
InfluxData.Net是可移植的.NET库,用于访问数据库和处理工具的RESTAPI。
该库支持.NetFrameworkv4.6.1和.NetStandardv2.0(这意味着.NetCore2.0)。
InfluxDB是的的数据存储层,它是一个开源的端到端平台,用于大规模管理时间序列数据。
Kapacitor是一个数据处理引擎。
它可以处理来自InfluxDB的流(订阅
2025/6/15 12:45:47 253KB database influxdb kapacitor series
1
Gitblit是一个用于管理,查看和提供Git存储库的开源纯Java堆栈。
它主要设计为希望托管集中式存储库的小型工作组的工具。
2025/6/5 6:26:12 40.4MB GitBlit
1
CodeIgniter4框架什么是CodeIgniter?CodeIgniter是一个PHP的完整堆栈Web框架,它轻便,快速,灵活且安全。
可以在找到更多信息。
该存储库包含框架的可分发版本,包括用户指南。
它是从构建的。
有关版本4计划的更多信息,请参见论坛上的。
可以在找到与该版本的框架相对应的用户指南。
index.php的重要更改index.php不再位于项目的根目录中!它已被移动的公共文件夹中,为更好的安全性和组分的分离。
这意味着,你应该配置你的Web服务器,以“点”到项目的公用文件夹,而不是项目的根。
更好的做法是将虚拟主机配置为指向该主机。
不良做法是将Web服务器指向项目根目录,并期望进入public/...,因为其余逻辑和框架都已公开。
请阅读用户指南,以更好地解释CI4的工作原理!目前,用户指南的更新和部署有些尴尬,但我们正在努力!仓
2025/6/4 18:37:37 1.6MB PHP
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
【DM365启动机制与Boot】深入解析

DM365是一款由德州仪器(TI)推出的DaVinci系列数字媒体处理器,广泛应用于多媒体设备、视频处理和图像处理等领域。
其启动过程涉及到复杂的硬件初始化和软件加载流程,理解这一过程对于开发和调试基于DM365的系统至关重要。


DM36X的启动机制遵循一个标准的流程,当系统加电或复位后,CPU会从预先设定的地址读取第一条指令。
DM36X提供了多种启动方式,主要分为两种:通过外部存储器接口AEMIF(NOR Flash/OneNand)引导启动和通过ARM内部ROM(AIROM)引导启动。
启动模式的选择由BTSEL[2:0]引脚的状态决定。


例如,当BTSEL[2:0]设置为001时,系统将从AEMIF执行引导启动代码,即从外部的OneNand或Nor Flash启动。
而AIROM则支持多种启动模式,包括BTSEL[2:0]=000的NAND Boot,BTSEL[2:0]=010的MMC/SD Boot,以及BTSEL[2:0]=101的SPI Boot等。


Nand Boot Mode是DM365的一种常见启动方式,但因为处理器的AIRAM空间有限且NAND Flash不支持XIP(执行-in-place)技术,因此需要经过三个阶段的代码来完成从NAND Flash引导启动操作系统。
这一流程包括了初始化硬件、加载用户引导加载器(UBoot)到内存以及执行UBoot。


User Bootloader是DM365启动过程中的关键部分,其源码主要位于PSP包的board_utilities/flash_utils目录下。
入门代码由汇编文件start.S开始,负责切换操作模式、建立堆栈,并跳转到main函数。
在main函数中,LOCAL_boot函数负责实际的引导功能,包括调用Device_init()和NANDBOOT_copy()。


Device_init()函数完成了平台的底层初始化,如电源域、时钟、DDR、EMIF、UART、I2C和TIMER等模块的设置。
它首先屏蔽和清除中断,然后通过调用DEVICE_PSCInit启用各模块的电源和时钟,接着配置PINMUX,设置PLL1,配置DDR控制器,EMIF模块,串口0,TIMER0和I2C控制器。


当检测到启动模式配置寄存器(BOOTCFG)的BTSEL[2:0]为000时,系统将调用NAND_init()初始化NAND Flash,并通过NANDBOOT_copy()将紧随其后的Bootloader代码复制到DDR2内存中,以便于后续的程序执行。


Bootloader是嵌入式系统的重要组成部分,它的主要任务是为操作系统提供加载环境。
Bootloader的特点包括:早期系统初始化、设备驱动加载、引导操作系统、支持交互式操作等。
根据工作模式,Bootloader可以分为固件阶段和加载阶段,前者主要负责硬件初始化,后者则负责加载操作系统映像。


DM365的启动过程涉及到硬件配置、软件加载和系统初始化等多个环节,对开发人员理解和优化系统性能具有深远的影响。
了解这些知识,可以帮助我们更好地理解和调试基于DM365的系统,提高其稳定性和效率。
2025/5/20 13:14:23 530KB
1
基于DimaWebApp的可观察性和测试研讨会免责声明此应用程序几乎没有内置安全性,因此如果不运行并打开互联网,则可能会面临风险,而您自己承担风险就运行该应用程序。
执照该应用程序在下运行,您也可以阅读更多信息。
欢迎来到迪马Dima应用程序是一个Web应用程序,具有围绕图像的基本功能。
该存储库的主要目的是为软件专业人员提供一个游乐场,以练习他们对软件应用程序的调试和检测,以提高可观察性。
因此,最小的DimaWebApp意味着可以行使超能力的遥测堆栈。
总是会发现错误和问题。
有些是计划好的,有些是有趣的巧合。
如果您在找不到任何内容,请创建请求请求,我们很乐意为您提供信息。
2025/5/6 20:58:49 21.46MB microservices workshop monitoring logging
1
共 195 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡