GSM呼叫流程图移动台的呼入接续过程:1、寻呼。
MSC/VLR在数据库中查出用户的资料并向相关的BSC发送寻呼信息。
该信息包含用户所在区域的LAI和用户的IMSI或者TMSI。
2、寻呼命令。
BSC向LA区内的所有BTS发出寻呼命令。
该信息包含IMSI或TMSI。
收发信单元识别码、信道类型和时隙号。
3、寻呼请求。
BTS在PCH上向移动台发送寻呼信息。
该信息包含用户的IMSI或TMSI。
4、信道请求。
被寻呼的移动台在RACH上发送一个短的接入脉冲串至BTS。
BTS接收该寻呼响应信号后记录该突发脉冲串的迟滞值。
(TA动态PWR)5、信道请求。
BTS向BSC发信道请求信息。
该信息还包含移动台接入系统的迟滞值(TA.PWR)。
6、信道激活。
BSC选择一条空闲的SDCCH并指示BTS激活该信道。
7、信道激活证实。
BTS激活SDCCH后向BSC发信道激活证实信息。
8、立即分配。
BSC透过BTS经由AGCH向移动台发出允许接入系统信息。
该信息包含频率、时隙号、SDCCH信道号和移动台将要使用的时间提前值TA等。
9、寻呼响应。
移动台通过SDCCH向BSC发寻呼响应信息。
该信息包含移动台的IMSI或TMSI和移动台的等级标记,BSC加入CGI后把信息送往MSC/VLR。
10、鉴权请求。
MSC/VLR透过BSC、BTS向移动台发鉴权请求,其中包含随机数RAND,用移动台的鉴权运算。
11、鉴权响应。
移动台经鉴权计算后向MSC/VLR发回鉴权响应信息,MSC/VLR检查用户全法性,如用户全法,则开始启动加密程序。
12、加密模式命令。
MSC/VLR通过BSC、BTS向移动用户发加密模式命令。
该命令在SDCCH上传送。
13、加密模式完成。
移动台进行加密运算后向BTS发出已加密的特定信号,BTS解密成功后透过BSC向MSC/VLR发加密模式完成信息。
14、设置呼叫类型。
MSC向移动台发送呼叫类型设置信息。
该信息包含该次呼叫的类型。
如传真、通话或数据通信等类型。
15、呼叫类型证实。
移动台设置好呼叫类型后向MSC发出呼叫类型证实信息。
16、分配请求。
MSC要求BSC选择一条通往移动台的话音信道,同时MSC在一条通往BSC的PCM上选择一个空闲时隙,并把时隙的电路识别码CIC送往BSC。
17、信道激活。
如果BSC发现某小区上有一条空闲的TCH,它将向BTS发送信道激活命令。
18、信道激活证实。
BTS激活TCH后向BSC发回信道激活证实信息。
19、分配命令。
BSC通过SDCCH向移动台发信道切换指令,命令移动台切换至所指定的TCH。
20、分配完成。
移动台切换至所指定的TCH后向BSC发送信道分配完成信息,BSC接收后再送往MSC/VLR。
21、无线频率信道释放/释放证实。
BSC释放SDCCH信道并把它标记为空闲状态。
22、振铃回应。
当移动台开始振铃时移动台要向MSC发送一个通知信息。
23、连接。
当移动台摘机应答时,移动台向MSC发送一个连接信息,MSC把移动台的电路接通,开始通话。
1
毕业自己写的,包括宿舍的添加,卫生检查,水电查询,分角色登录,个人觉得做的不错
2025/5/27 14:24:18 5.12MB C# winform 宿舍管理系统
1
STM32PACK包是STMicroelectronics为KeilMDK用户提供的一种便利工具,它包含了STM32微控制器的设备描述文件(DeviceFamilyPackage,DFP),用于在开发环境中支持STM32系列芯片。
这个RAR压缩包名为"STM32_PACK包.rar",其主要目的是为KeilMDK用户提供快速获取所需的固件库和设备驱动,避免了在线下载的繁琐和时间消耗。
"STM32F0xx_DFP.2.1.0.pack"和"STM32F1xx_DFP.2.1.0.pack"是两个不同的PACK文件,分别对应STM32F0系列和STM32F1系列的设备支持包。
以下将详细讲解这两个文件包含的知识点:1.STM32F0xxDFP:这个文件提供了STM32F0系列微控制器的完整硬件描述,包括寄存器定义、中断向量表、外设驱动等。
STM32F0是ST公司的超低功耗微控制器,基于ARMCortex-M0内核,适用于各种嵌入式应用。
DFP使得开发者能在KeilMDK中轻松配置和编程这些芯片,进行功能验证和系统级调试。
2.STM32F1xxDFP:类似地,STM32F1xxDFP针对的是STM32F1系列,这是基于ARMCortex-M3内核的微控制器,具有更高的处理能力和更丰富的外设接口。
DFP包含的详细信息使得开发者能充分利用STM32F1的各种特性,如ADC、DMA、定时器、串口、USB等,进行复杂项目的设计和实现。
3.KeilMDK:是一款广泛使用的嵌入式开发工具套件,由ARM公司授权,包含C/C++编译器、调试器、仿真器、项目管理工具等。
PACK包是KeilMDK的一个重要组成部分,它可以自动安装和更新所需的固件库,简化开发流程。
4.设备描述文件(DFP):DFP是KeilMDK对特定微控制器或微处理器的支持文件,它定义了芯片的所有寄存器、中断向量以及相关的外设驱动程序。
当开发人员在KeilMDK中创建新项目时,选择对应的DFP,可以自动导入必要的头文件和库,加速开发进程。
5.版本号(2.1.0):这代表了DFP的版本,通常更新会修复已知问题,添加新特性,或者兼容新的芯片。
开发者应定期检查更新,确保使用的是最新版本,以获取最佳的开发体验和最稳定的代码。
6.使用方法:用户需要在KeilMDK中安装这个PACK包,然后在新建项目时选择对应的STM32系列和设备,这样MDK就会自动配置好所有必要的库和驱动。
接着,用户就可以开始编写代码,利用Keil的强大调试工具进行单步调试、查看变量、设置断点等。
STM32PACK包对于基于KeilMDK的STM32开发工作至关重要,它极大地简化了开发环境的配置,提升了开发效率,使得开发者能够更专注于应用程序的开发,而不是底层驱动的构建。
2025/5/26 9:27:13 111.44MB PACK包 stm32
1
电报在线状态记录器机器人。
“我郑重发誓我无能为力。
”〜哈利·波特宇宙使用Telethon库检查联机状态以及是否已更改。
如果检测到更改,则漫游器会向您发送消息。
这个怎么运作spy.py将托管一个您可以与之交互的机器人。
在Telegram上,您可以与bot聊天,并通过bot命令在监视列表中添加/删除用户。
如果列表中的任何用户更改了其在线状态,则该漫游器会向您发送消息。
安装pipinstalltelethon建立在上创建您的电报应用程序,并将API_HASH和API_ID替换为您的API。
API_HASH='yourapihash'API_ID=
2025/5/25 6:31:30 141KB tracker bot monitoring online
1
算法思想: 本实验采用贪心算法的思想。
将集装箱想象成为一个长为L、宽为W、高为H的长方体,将圆柱形木材想象成为一底面半径为ri、长为L的圆柱体。
1、首先需要对圆柱体按半径从大到小进行排序,排完序后将其分为两部分:一部分为已经放在矩形适当位置的(初始化为空),另一部分为剩下的尚未进行定位的圆柱体;
2、接着取出剩下的圆柱体中底面半径最大的一个,从左下角的坐标开始检查矩形空闲位置并判断当前圆柱体是否可以放入(判断圆柱体底面圆的圆心距是否合适,以及底面面积是否超过了空闲矩形的边框)。
若可以,则放入之,并标记当前放入的圆柱体,记下其坐标;
3、接下来再将剩余的圆柱体取出,重复步骤2直至矩形空间中不再能够容纳下剩余圆柱体中(如果还有剩余的话)底面半径最大的一个圆柱体;
4、算法结束。
2025/5/25 0:10:45 47KB 装箱问题 C++ 算法 程序
1
银行家算法是死锁避免的经典算法,其核心思想是:进程动态地申请资源,每次申请资源时系统都执行安全状态检查算法判断本次申请是否会造成系统处于不安全状态,如果不安全则阻塞进程;
如果安全状态,则完成资源分配。
安全状态检查算法的思想是找到一个安全序列,使所有进程都能执行完毕。
如果找到,则处于安全状态,否则为不安全状态。
1
SAE J1699-1-2021 是一份关于道路车辆OBD-II(On-Board Diagnostics II)验证测试程序的标准文档,由SAE(美国汽车工程师学会)发布,旨在推动汽车技术与工程科学的发展。
这个标准是自愿采用的,其适用性和对于任何特定用途的适合性,包括可能由此引发的专利侵权问题,均由使用者自行负责。


OBD-II系统是汽车诊断的一种标准,它允许技术人员通过车辆的数据端口访问和分析车辆的故障信息。
SAE J1699-1标准详细规定了如何验证这些系统是否符合规定的性能和兼容性要求。
这份2021年的更新版本是对2006年版的J1699-1标准的修订或确认,确保与当前汽车技术保持同步。


J1699-1标准的稳定化(Stabilized)状态意味着其中涵盖的技术、产品或过程已经成熟,不太可能在可预见的未来发生重大变化。
这意味着尽管这个标准被认定为稳定,但用户仍然需要定期检查参考信息,以确保技术要求的持续适用性,因为可能存在更新的技术。


此标准包含了OBD-II系统的测试步骤和程序,旨在确保车辆制造商生产的OBD-II接口能够准确、一致地报告和处理车辆的诊断信息。
这些测试可能包括但不限于通信协议一致性、故障代码设置的正确性、故障指示灯的触发条件以及数据流的准确传输。


该标准还涉及到SAE J1850,这是一个早期的通信协议,用于OBD-II系统中,用于在车辆的ECU(电子控制单元)和诊断工具之间交换信息。
J1699-1标准可能会扩展到其他通信协议,以适应现代车辆中更复杂的网络架构和更高的数据传输需求。


SAE J1699-1-2021的实施可以帮助确保车辆的排放控制系统的有效性,因为它要求OBD-II系统能够检测和报告任何可能导致排放超过法定限值的故障。
这有助于维护环境法规的执行,并促进汽车行业的技术进步和创新。


要获取这份标准的完整内容,可以联系SAE International,通过电话、传真或电子邮件下单,或者访问其官方网站进行在线购买。
同时,SAE也鼓励用户提供书面评论和建议,以帮助持续改进这些标准。
2025/5/21 22:54:09
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
在本文中,我们将深入探讨DM365芯片的启动流程,特别是针对NAND和UART两种启动模式。
DM365是一款基于DaVinci技术的多媒体处理器,其启动机制涉及到多个组件,包括MMU、数据缓存和指令缓存,以及不同类型的BootLoader。
MMU(内存管理单元)在启动阶段必须关闭,这意味着在这个阶段,虚拟地址与物理地址是相同的,这简化了对内存的访问。
数据缓存和指令缓存则用于提高处理器对内存数据的存取速度,它们在启动过程中起到加速代码执行的作用。
DM365的启动模式可以通过设置BTSEL[2:0]跳线来选择。
当设置为001时,系统会从外部的NORFLASH启动;
其他设置则会从内部ROM启动,执行固化在ROM中的RBL(ROMBootLoader)。
RBL是一个不可擦除的BootLoader,负责加载用户定义的UBL(UserBootLoader)到内存特定地址执行。
UBL的大小有限,不能超过14K,因此无法直接包含完整的U-BOOT。
为了启动U-BOOT,我们需要一个小于14K的小型UBL,它位于NANDFlash的前5个block内。
启动流程如下:1.RBL运行,检查NANDFlash设备ID。
2.如果设备ID匹配,RBL查找UBL的描述信息。
3.RBL将UBL复制到ARM内部RAM,并进行ECC校验。
4.UBL加载后,可以进一步加载U-BOOT和操作系统。
对于NANDBOOT模式,RBL会尝试读取NANDFlash的设备ID,然后查找并加载UBL。
如果失败,会尝试其他启动模式,如MMC/SD。
对于UARTBOOT,RBL通过串口与主机程序交互,发送BOOTME信号并等待ACK,以完成UBL的传输。
在UARTBOOT过程中,串口设置和通信协议是关键,RBL与主机程序的交互确保了UBL的正确接收。
一旦UBL通过UART传输到DM365,后续的启动流程与NANDBOOT类似。
DM365的启动涉及多层BootLoader,每层都有特定的任务,从初始化硬件到加载操作系统。
理解这些启动机制对于开发和调试基于DM365的系统至关重要,尤其是在需要自定义启动流程或优化性能时。
同时,熟悉MMU、缓存的工作原理也是优化系统性能的关键。
2025/5/20 15:52:57 326KB
1
某大学拟开发一个计算机分房管理系统,要求系统具有分房、调房、退房和咨询统计等功能。
房产科把用户申请表输入系统后,系统首先检查申请表是否合理,对不合法申请表拒绝接受;
对合法表根据类型进行处理。
分房申请,根据申请者情况(年龄、工龄、职称、职务、家庭人口等)计算其分数,高于阀值的进行排队。
分房时,读空房文件,把好房优先分给排在分房队列前面的人,并将房屋信息与申请者一起写入住房文件中。
若为退房申请,从住房文件中删除有关信息,并将房屋信息计入空房文件。
若是调房申请,根据申请者情况计算分数,并进行以上退房和分房处理。
系统可进行房屋信息维护(输入、删除、排序),以及各种住房信息统计、查询、打印等。
2025/5/20 12:26:19 9.58MB vb
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡