`
384444165
  • 浏览: 261386 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

深入阅读Mina源码(1) —— 小试牛刀,过滤器介绍

阅读更多

(ps:写完后觉着第一博还是应该说一下Mina的简介,就附上了0部分吧)

 

0. Mina框架简介 

 

    MINA(Multipurpose Infrastructure for Network Applications)是用于开发高性能和高可用性的网络应用程序的基础框架。通过使用MINA框架可以可以省下处理底层I/O和线程并发等复杂工作,开发人员能够把更多的精力投入到业务设计和开发当中。MINA框架的应用比较广泛,应用的开源项目有Apache Directory、AsyncWeb、Apache Qpid、QuickFIX/J、Openfire、SubEthaSTMP、red5等。

    MINA框架的特点有:基于java NIO类库开发;采用非阻塞方式的异步传输;事件驱动;支持批量数据传输;支持TCP、UDP协议;控制反转的设计模式(支持Spring);采用优雅的松耦合架构;可灵活的加载过滤器机制;单元测试更容易实现;可自定义线程的数量,以提高运行于多处理器上的性能;采用回调的方式完成调用,线程的使用更容易。 

 

1. 引言

 

    近期的项目需要用到Mina,比较粗浅的在上层简单的搭建自己的项目,但是有种非常疑惑并且没有安全感的想法,就决定看下Mina的源码,并且网络部分的知识还是很重要的。第一次写源码分析的博客,也没有经验,不知道怎么说好,是不是需要细致摄入。我就避开入门和介绍部分,直接分析源码了,可能比较细微一点,也留作自己日后查看。(ps:如果要找Mina的介绍、入门相关的博客在iteye一搜就会有很多相关的介绍的,可以先看一下整体框架和基本的使用方法,方便理解)

    直接看源码可能会有找不到头绪的事情,站在巨人的肩膀上还是很好的方法,我选择了这个博客,先给出作者的地址,我会首先按照作者的思路分成四部分介绍,如果需要补充在增加文章,还是很推荐这几篇文章,有些作者说的清楚的我就不再重复描述,但是对于有些说的不清楚,或UML图有问题的我会说明一下,做少量的引用。


    http://wslfh2005.iteye.com/ 作者有四篇文章,不再详细列出,


    如果查看了Mina的入门博客,或者官方文档肯定对于类似下面这个图比较熟悉了,可以很清楚的看到IoFileterChain的过滤层,Mina对三层进行了很好的分离,使得连接维护,信息的预处理,逻辑处理很好的分离。我们首先来单个模块剥离,按照推荐的博客的顺序首先介绍过滤器层。

 

 

2.Mina过滤器机制的实现

 

 

 Mina的核心代码都在core中,包结构也很清晰,此部分代码都在core.filterchain中,目录下有一下几个类:

 

   

 

最重要的基础类和接口是:IoFilter、IoFilterChain、DefaultIoFilterChain。

这个图和引用的博客的图都不能很好的看出来这些文件的直接关系,下面就先看一下,有个直观认识

 

 

2.1 IoFilter

 

    看一下IoFilter定义的方法,可以把IoFilter简单的分成两部分。

    一部分是跟IoFilterChain相关的,在添加、删除相应的Filter之后调用,如:

 

 

/**
     * Invoked before this filter is added to the specified <tt>parent</tt>.
     * Please note that this method can be invoked more than once if
     * this filter is added to more than one parents.  This method is not
     * invoked before {@link #init()} is invoked.
     *
     * @param parent the parent who called this method
     * @param name the name assigned to this filter
     * @param nextFilter the {@link NextFilter} for this filter.  You can reuse
     *                   this object until this filter is removed from the chain.
     */
    void onPreAdd(IoFilterChain parent, String name, NextFilter nextFilter) throws Exception;
 

    另一部分是跟消息处理相关的,如:

 

 

/**
     * Filters {@link IoHandler#messageReceived(IoSession,Object)}
     * event.
     */
    void messageReceived(NextFilter nextFilter, IoSession session, Object message) throws Exception;
 

    其他就是跟初始化、销毁等相关的操作了。


    可以看到IoFilter的实现类IoFilterAdapter中其实没有过多的实现其中细致的操作,在sessionCreated等session相关和Message相关的方法中相应的调用了nextFilter的对应方法完成消息的传递,作为父类,可以看到消息传递的影子了。

    这里最值得关注的部分在于IoFilter中其中定义了一个NextFilter接口,NextFilter包含了IoFilter中提到的两部分全部方法,没有包含最后提到的初始化、销毁等相关的代码,而且最奇怪的就是在IoFilterAdapter没有实现这个接口。观察这个包的类图和命名,可以想象的到在维护消息连的DefaultIoFilterChain中肯定实现了此接口,通过找到EntryImpl的构造函数中为nextFilter赋值的时候实现了此接口,先避开细节只看nextFilter

 

 

public void sessionCreated(IoSession session) {
        Entry nextEntry = EntryImpl.this.nextEntry;
        callNextSessionCreated(nextEntry, session);
}

private void callNextSessionCreated(Entry entry, IoSession session) {
        try {
            IoFilter filter = entry.getFilter();
            NextFilter nextFilter = entry.getNextFilter();
            filter.sessionCreated(nextFilter, session);
        } catch (Throwable e) {
            fireExceptionCaught(e);
        }
}

 

    这段代码直接反应了所有方法的实现,都是通过这一种方式实现了转发的作用,这也是整个NextFilter方法的作用,具体的业务逻辑依然在Filter中执行,相同的名字只是为了维持含义的一致性,NextFilter的实例则维护在EntryImpl。下面就进入IoFilterChain看一下这个类。

 

2.2 IoFilterChain

 

    下面就按照最直观的名字先来看IoFilterChain,接口用来构造一个容器管理所有的IoFilter,里面更细节的定义了一个Entry接口,来表示每个FilterChain中的节点,Entry定义的方法如下

 


    现有个直观的认识,可以看到entry内容非常少,作用就是完成了维护前后和本身的IoFilter的工作,使得所有的Entry通过自身中的记录组成了一条链。

通过之前的图可以看到DefaultIoFilterChain是Mina给出的IoFilterChain默认实现类,因此必然有Entry的实现,找到发现是EntryImpl,EntryImpl构造函数为:

    private EntryImpl(EntryImpl prevEntry, EntryImpl nextEntry, String name, IoFilter filter) 

    通过这个构造函数就可以看出是如何实现前面的接口的了,只是为什么需要preEntry呢,只是为了传入Filter吗,如果答案是是的话Mina肯定不会这么做的。这里又一次要看NextFilter这个接口的实现了,可以看到filterWrite和filterClose方法都是逆向传递的:

 

 

public void filterWrite(IoSession session, WriteRequest writeRequest) {
        Entry nextEntry = EntryImpl.this.prevEntry;
        callPreviousFilterWrite(nextEntry, session, writeRequest);
}

public void filterClose(IoSession session) {
        Entry nextEntry = EntryImpl.this.prevEntry;
        callPreviousFilterClose(nextEntry, session);
}

 


    这里就看到了为什么Mina要大费干戈,而不采用简单的方式实现,和这里NextFilter接口设计的精妙之处,第一张架构图中可以看到消息传递的双向性,不管是服务器和客户端,消息的接受和发送总是反方向进行的,起点也不同。而通过实现nextFilter接口其实就很好的封装了消息传递的顺序,仅仅在Entry一层去控制所有方法向上还是向下传递,而对于外部的消息连而言只需要调用跟Filter同名的方法即可,虽然这里看到了调用的Chain中带有Previous和Next的方法,但是实际上内部并没有做相应的行为,都是只简单的获取nextFilter,因为nextFilter中的方法已经定义了相应的向上和向下传递。至于为什么叫这个名字应该是为了很好的表明这些方法的顺序和含义,另外nextFilter中调用的Chain中的方法全部都是private,因此对子类理解和修改没有影响。(刚才代码中调用的callPreviousFilterWrite如下)

 

 

private void callPreviousFilterWrite(Entry entry, IoSession session, WriteRequest writeRequest) {
        try {
            IoFilter filter = entry.getFilter();
            NextFilter nextFilter = entry.getNextFilter();
            filter.filterWrite(nextFilter, session, writeRequest);
        } catch (Throwable e) {
            writeRequest.getFuture().setException(e);
            fireExceptionCaught(e);
        }
}

 

    前面主要说的entry和nextfilter,接下来就单纯的针对Chain来看一下做了什么事情。DefaultIoFilterChain中维护了一个header和tail,很容易想到的就是链表,刚才提到entry通过内部的维持其实很方便来实现这样的链表。因此DefaultIoFilterChain的作用就是维护链表、提供nextFilter调用的filter相关方法完成传递,最后TailFilter将消息传递给IOHandler处理。包括IoFilterChain接口中除了fire方法也只是定义了很多关于链表的操作(fire方法后面再说)。

 

2.3 IoFilterEvent

 

    该类继承IoEvent,完成基于事件的处理模型,当一个事件(比如接收到消息)发生后会触发相应的事件,进而调用过滤器链的消息处理功能进行消息的处理和转发。这也是下一节要说的,提到这个类,因为刚才漏下了IoFilterChain的一系列fire方法没有介绍,如果不说显得不太完整了,IoFilterEvent基本只为了一个fire方法,就是根据构造方法中传入的IoEvent事件的类型区调用相应的nextFilter的方法,这里只是为子类提供一种事件处理的机制,搜索一下此类,可以看到在实现具体的filter时有些地方用到了,去更好的完成Filter或基于事件的流程控制(core之外的包看的少,不多误导)。另外从IoFilterEvent中可以看到这个利用NextFilter时已经不可见消息传递的方向了。根据事件去传递,用chain中提供的fire系列方法也可以同样完成。这个类代码很少,就不再粘贴和介绍。

 

2.4 DefaultIoFilterChainBuilder和IoFilterChainBuilder

 

    接口就是builder机制,不多说。细说一下实现类,它是个builder机制,但是它完成了很多IoFIlterChain需要完成的工作,它直接利用并发包中的CopyOnWriteArrayList来提供一个chain的构造操作,并且尚未构建IoFIlterChain之前,是可以修改list中的filter的,整个list的维护都对用户可见。builder实现了自己的entry,但是相对来说很简单,没有再每个entry维持链接关系。


    继承自接口的主要是build方法:

 

 

public void buildFilterChain(IoFilterChain chain) throws Exception {
        for (Entry e : entries) {
            chain.addLast(e.getName(), e.getFilter());
        }
}

 

 

    只是简单地把entry交进去,那链接关系是怎么创建的呢。感兴趣可以看一下DefaultIoFilterChain的addLast,其中检查了可插入行后就调用了register方法。

 

 

private void register(EntryImpl prevEntry, String name, IoFilter filter) {
        EntryImpl newEntry = new EntryImpl(prevEntry, prevEntry.nextEntry, name, filter);

        try {
            filter.onPreAdd(this, name, newEntry.getNextFilter());
        } catch (Exception e) {
            throw new IoFilterLifeCycleException("onPreAdd(): " + name + ':' + filter + " in " + getSession(), e);
        }

        prevEntry.nextEntry.prevEntry = newEntry;
        prevEntry.nextEntry = newEntry;
        name2entry.put(name, newEntry);

        try {
            filter.onPostAdd(this, name, newEntry.getNextFilter());
        } catch (Exception e) {
            deregister0(newEntry);
            throw new IoFilterLifeCycleException("onPostAdd(): " + name + ':' + filter + " in " + getSession(), e);
        }
}

 

    register方法又把有用的参数构造了新的DefaultIoFilterChain自己实现的EntryImpl, 肯定记得这样就会产生新的nextFilter,来调用entry中存储的前后节点,从而完成了chain的组成。

 

 

2.5 IoFilterLifeCycleException

 

    最后exception只是继承了RuntimeException,没有做其他的事情,用来标明是infilter中onPostAdd、onPreAdd等在加入Chain之前的操作发生异常。

 

 

2.6 Conclusion

 

    此部分主要是介绍了core中的消息链实现的机制,下面还要继续深入阅读其他部分源码,继续分享。因为是按照单独的模块阅读的代码,可能存在一些短见和没认识到的机制。最后看完所有的之后再做一次整合的介绍,和一个Mina上层的demo案例。今天到这了,碎觉。

分享到:
评论

相关推荐

    基于S7-200 PLC和MCGS组态的转速闭环调速系统:带解释的梯形图程序、接线图原理图图纸、IO分配及组态画面

    内容概要:本文详细介绍了如何利用S7-200 PLC和MCGS组态软件构建一个转速闭环调速系统。主要内容涵盖系统的硬件配置、梯形图程序设计、接线图原理、IO分配以及组态画面的设计。文中还深入探讨了PID控制器的应用及其参数整定方法,确保电机能够稳定运行并达到预期的转速控制精度。此外,作者分享了一些实际调试过程中遇到的问题及解决方案,如编码器脉冲数过高导致的计算溢出、接地不当引起的转速不稳定等。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是对PLC编程和组态软件有一定了解的人群。 使用场景及目标:适用于需要精确控制电机转速的工业应用场景,如生产线、包装线等。目标是帮助读者掌握如何搭建和优化转速闭环调速系统,提高生产效率和产品质量。 其他说明:文章不仅提供了理论指导,还结合了大量实践经验,有助于初学者快速上手并解决实际问题。

    基于python实现进行股票分析和选股+源码+项目文档+使用说明(毕业设计&课程设计&项目开发)

    基于python实现进行股票分析和选股+源码+项目文档+使用说明,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档 使用python进行股票历史数据下载和分析选股。除了选股策略以外,其他都可公开。 git网站上有很多优秀开源量化平台项目。本项目与其他项目的区别是,本项目侧重于选股、回测所需数据的导入工作。有了历史数据和选股策略,选择哪个量化平台做回测都是很轻松的事情了。 业余编程水平,需求导向。才疏学浅,刚学python几个月时间。git主要作为云端git库使用。无任何解答服务。 力求选择最稳定可靠的数据获取方式。虽然网上有很多数据源平台,但都受制于“积分”、带宽、平台是否更新等,完全是把程序主动权交到了对方手里。因此本项目所有数据依靠本地通达信软件导出提供

    ​​基于Swin Transformer与ASPP模块的图像分类系统设计与实现​

    基于Swin Transformer与ASPP模块的图像分类系统设计与实现 本文介绍了一种结合Swin Transformer与空洞空间金字塔池化(ASPP)模块的高效图像分类系统。该系统通过融合Transformer的全局建模能力和ASPP的多尺度特征提取优势,显著提升了模型在复杂场景下的分类性能。 模型架构创新 系统核心采用Swin Transformer作为骨干网络,其层次化窗口注意力机制能高效捕获长距离依赖关系。在特征提取阶段,创新性地引入ASPP模块,通过并行空洞卷积(膨胀率6/12/18)和全局平均池化分支,实现多尺度上下文信息融合。ASPP输出经1x1卷积降维后与原始特征拼接,有效增强了模型对物体尺寸变化的鲁棒性。 训练优化策略 训练流程采用Adam优化器(学习率0.0001)和交叉熵损失函数,支持多GPU并行训练。系统实现了完整的评估指标体系,包括准确率、精确率、召回率、特异度和F1分数等6项指标,并通过动态曲线可视化模块实时监控训练过程。采用早停机制保存最佳模型,验证集准确率提升可达3.2%。 工程实现亮点 1. 模块化设计:分离数据加载、模型构建和训练流程,支持快速迭代 2. 自动化评估:每轮训练自动生成指标报告和可视化曲线 3. 设备自适应:智能检测CUDA可用性,无缝切换训练设备 4. 中文支持:优化可视化界面的中文显示与负号渲染 实验表明,该系统在224×224分辨率图像分类任务中,仅需2个epoch即可达到92%以上的验证准确率。ASPP模块的引入使小目标识别准确率提升15%,特别适用于医疗影像等需要细粒度分类的场景。未来可通过轻量化改造进一步优化推理速度。

    基于SSH框架的电脑商城系统全套教程:从源码到运行,初学者参考指南,附详细文档与演示视频。

    内容概要:本文详细介绍了一个基于SSH(Struts2 + Spring + Hibernate)框架构建的电脑商城系统的实现细节。涵盖了用户注册、购物车管理、秒杀功能、商品管理和后台权限控制等多个核心模块。通过具体的代码示例和技术要点解析,展示了如何利用这三个框架的优势来实现一个完整的电商系统。同时,文中还提到了一些常见问题及其解决方案,如数据库表结构设计、事务配置、定时任务、缓存机制以及前端交互等。 适合人群:具备一定Java基础,特别是对SSH框架感兴趣的初学者和中级开发者。 使用场景及目标:①帮助读者理解SSH框架的工作原理和应用场景;②提供一个完整的电商系统案例供学习和参考;③解决实际开发过程中可能遇到的技术难题。 其他说明:项目不仅包含详细的文档和源码,还包括PPT演示和运行录屏,非常适合自学和教学使用。建议从简单的注册登录功能开始,逐步深入到复杂的业务逻辑和性能优化。

    基于Matlab GUI的FIR数字滤波器设计:窗函数法与等波纹逼近法实现多类型数字滤波器设计

    内容概要:本文详细介绍了如何使用Matlab的GUI功能设计低通、高通、带通、带阻等多种类型的FIR数字滤波器。首先解释了FIR滤波器的基本概念及其优点,然后重点讨论了两种常用的设计方法:窗函数法和等波纹最佳逼近法。窗函数法通过选择不同的窗函数(如矩形窗、凯塞窗)来截断理想的时域冲激响应,实现简单但频响特性存在一定的局限性。等波纹最佳逼近法则采用Parks-McClellan算法,确保通带和阻带内的最大纹波最小,频响特性更为优越。此外,还展示了如何利用Matlab的App Designer创建交互式的GUI工具,使用户能够实时调整滤波器参数并查看频响特性。 适合人群:具有一定MATLAB基础的工程师和技术爱好者,尤其是从事数字信号处理领域的研究人员。 使用场景及目标:①掌握FIR滤波器设计的基本理论和方法;②学会使用Matlab进行窗函数法和等波纹法的具体实现;③通过GUI工具提高滤波器设计的效率和直观性。 其他说明:文中提供了详细的代码示例和注意事项,帮助读者更好地理解和应用所学知识。

    基于PCA的EC管外壁阻垢率预测模型研究.pdf

    基于PCA的EC管外壁阻垢率预测模型研究.pdf

    数据集-目标检测系列- 牙刷 检测数据集 toothbrush >> DataBall

    数据集-目标检测系列- 牙刷 检测数据集 toothbrush >> DataBall 标注文件格式:xml​​ 项目地址:https://github.com/XIAN-HHappy/ultralytics-yolo-webui 通过webui 方式对ultralytics 的 detect 检测任务 进行: 1)数据预处理, 2)模型训练, 3)模型推理。 脚本运行方式: * 运行脚本: python webui_det.py or run_det.bat 根据readme.md步骤进行操作。

    基于蚁群算法的双向平滑路径规划算法研究与Matlab实现 通过自主研究对比,实现起始点与地图的自由更换优化路径选择。

    内容概要:本文深入探讨了路径规划算法的研究进展,特别是对经典的蚁群算法进行了多项创新性的改进。作者详细介绍了如何利用Matlab实现蚁群算法的基本框架,并针对路径平滑度不足的问题提出了基于Flod算法的双向平滑度优化方法。此外,还自主研发了一种全新的路径规划算法,能够灵活应对不同的地图环境。通过对多种算法的实际性能对比,展示了改进后的蚁群算法在路径长度和平滑度方面的显著提升。 适合人群:对路径规划算法感兴趣的科研人员、工程师以及高校师生。 使用场景及目标:适用于需要高效、平滑路径规划的应用场合,如机器人导航、物流配送系统等。目标是为用户提供一种更为智能化、高效的路径解决方案。 其他说明:文中提供了详细的代码片段和技术细节,有助于读者理解和复现实验结果。同时,强调了算法在实际应用场景中的表现和潜在价值。

    tMFPA:花朵授粉算法(FPA)复现及改进——包括Logistic混沌初始化种群、t分布扰动异花授粉与差分思想自花授粉的23个基准测试函数研究

    内容概要:本文介绍了花朵授粉算法(FPA)的一种改进版本——tMFPA。主要改进之处在于采用Logistic混沌初始化种群、t分布扰动进行异花授粉以及引入差分进化思想用于自花授粉。通过这三个方面的改进,tMFPA在多个基准测试函数上表现出更好的优化性能,尤其是在多峰函数和高维复杂问题上。文中详细描述了各个改进部分的具体实现方法及其背后的理论依据,并提供了具体的代码片段。此外,作者还分享了一些实用技巧和注意事项,如参数的选择和调整。 适合人群:对优化算法感兴趣的科研人员、算法开发者以及希望深入了解花朵授粉算法及其改进的学生。 使用场景及目标:适用于解决复杂的非线性优化问题,尤其是那些存在多个局部最优解的问题。目标是提高优化效率,加快收敛速度并获得更高的求解精度。 其他说明:作者将完整的代码上传到了GitHub,方便读者下载和进一步研究。同时,文中提到的一些可视化工具可以帮助用户更好地理解和跟踪算法的执行过程。

    Rust函数式编程:Monad与Functor模式实现.pdf

    文档支持目录章节跳转同时还支持阅读器左侧大纲显示和章节快速定位,文档内容完整、条理清晰。文档内所有文字、图表、函数、目录等元素均显示正常,无任何异常情况,敬请您放心查阅与使用。文档仅供学习参考,请勿用作商业用途。 Rust 以内存安全、零成本抽象和并发高效的特性,重塑编程体验。无需垃圾回收,却能通过所有权与借用检查机制杜绝空指针、数据竞争等隐患。从底层系统开发到 Web 服务构建,从物联网设备到高性能区块链,它凭借出色的性能和可靠性,成为开发者的全能利器。拥抱 Rust,解锁高效、安全编程新境界!

    基于PLC的饮料灌装生产线控制系统的电气设计与实现:触摸屏操作与详细图纸解析

    内容概要:本文详细介绍了基于PLC(可编程逻辑控制器)的饮料灌装控制系统的设计与实现。首先阐述了电气设计的基础,包括IO分配的具体方法及其在饮料灌装系统中的应用实例。接着深入探讨了梯形图编程,解释了如何通过逻辑运算控制灌装头的启停,确保灌装过程的安全性和准确性。此外,还讲解了接线图与原理图的作用,以及如何利用触摸屏进行人机交互,提升操作便捷性和实时监控能力。最后,分享了一些实际调试经验和故障排除技巧,强调了硬件布线和程序逻辑紧密结合的重要性。 适合人群:从事自动化控制领域的工程师和技术人员,尤其是对PLC编程和饮料灌装控制系统感兴趣的读者。 使用场景及目标:适用于饮料生产企业,旨在提高灌装生产线的自动化水平和控制精度,减少人工干预,提升生产效率和产品质量。 其他说明:文中提供了具体的IO分配示例、梯形图代码和触摸屏组态画面设计思路,帮助读者更好地理解和实施相关技术。同时,还提到了一些常见的调试问题及解决方案,如电磁阀响应延迟、气动阀响应延迟等,为实际应用提供指导。

    印刷量子点点阵信息可靠性编解码算法.pdf

    印刷量子点点阵信息可靠性编解码算法.pdf

    污水处理系统与项目全套完整方案

    内容概要:本文详细介绍了污水处理系统的全流程解决方案,涵盖通讯配置、配电柜设计、电气原理图、工艺流程图以及1200PLC源程序详解。针对常见的技术难点进行了深入剖析,提供了实用的操作技巧和优化建议。具体包括Modbus TCP配置、水泵变频器散热设计、曝气池控制逻辑、IO配置冗余设计、报警处理程序、PID参数整定等方面的内容。此外,还分享了丰富的调试经验和故障处理方法,确保系统稳定可靠运行。 适合人群:从事污水处理项目的设计、实施和维护的技术人员,尤其是具有一定PLC编程基础和电气工程经验的专业人士。 使用场景及目标:帮助技术人员快速掌握污水处理系统的构建要点,避免常见错误,提高工作效率。适用于新建或改造污水处理设施的工程项目,旨在提供全面的技术支持和实践经验指导。 其他说明:文中提供的资料基于真实项目案例,经过实战验证,具有较高的参考价值。建议读者结合自身实际情况灵活应用相关技术和方法。

    MATLAB编写的仿真VIVADO定点数转浮点数的函数

    本资源是MATLAB编写的仿真VIVADO定点数转浮点数的函数。 函数接口说明如下: function float_out = fixed2float(fixed_in, int_bits, frac_bits) % 将定点数转换为单精度浮点数 % 输入: % fixed_in - 定点数输入(字符串(双引号)定点形式,可以是标量、向量或矩阵) % int_bits - 整数部分位宽(包含符号位) % frac_bits - 小数部分位宽 % 输出: % float_out - 单精度浮点数 fixed_in的长度最大支持80位的定点数。int_bits和frac_bits的值可随意设置,确保它俩加起来等于fixed_in的长度即可。 fixed2dec函数是fixed2float调用的一个函数,目的是将定点数转为十进制数,也是自己编写的。 两个函数均有详细的接口注释说明。 本资源中所有的代码关键处均包含文字注释,注释很多,编写的代码逻辑清晰,方便各位小伙伴理解、阅读、学习、调试。 下载资源了的小伙伴有疑惑的可以私信我一起解决你的问题。下载该资源,直接就可以使用。

    Rust嵌入式日志系统:defmt高效输出.pdf

    文档支持目录章节跳转同时还支持阅读器左侧大纲显示和章节快速定位,文档内容完整、条理清晰。文档内所有文字、图表、函数、目录等元素均显示正常,无任何异常情况,敬请您放心查阅与使用。文档仅供学习参考,请勿用作商业用途。 Rust 以内存安全、零成本抽象和并发高效的特性,重塑编程体验。无需垃圾回收,却能通过所有权与借用检查机制杜绝空指针、数据竞争等隐患。从底层系统开发到 Web 服务构建,从物联网设备到高性能区块链,它凭借出色的性能和可靠性,成为开发者的全能利器。拥抱 Rust,解锁高效、安全编程新境界!

    基于Matlab的国外车牌识别:图像处理与文本分割算法在车牌检测中的应用

    内容概要:本文详细介绍了如何使用Matlab及其图像处理工具箱实现国外车牌识别系统。首先通过对输入图像进行预处理,包括灰度化、高斯滤波去噪、边缘检测等步骤,确保图像质量。然后利用形态学操作和区域属性筛选出符合特定长宽比的车牌区域。接下来采用垂直投影法或连通域分析法进行字符分割,并最终通过OCR技术将分割出的文字转换为可读字符串。文中还讨论了针对不同国家车牌特色的个性化处理方法以及提高识别精度的各种技巧。 适合人群:对图像处理和车牌识别感兴趣的科研人员、学生及开发者。 使用场景及目标:适用于希望深入了解车牌识别技术原理并尝试构建自己的车牌识别系统的个人或团队。目标是在常见条件下达到较高的车牌识别成功率。 其他说明:尽管传统算法能够满足大部分日常需求,但在极端环境下(如恶劣天气)仍存在局限性,因此文中也提到了进一步优化的方向,例如引入深度学习模型等。

    COMSOL纳米摩擦发电机数值计算模型:通过电极感应电荷密度计算电势和电场分布

    内容概要:本文详细介绍了如何利用COMSOL软件进行纳米摩擦发电机(TENG)的数值模拟,特别是电荷密度与电场分布的计算。首先,通过定义电荷密度变量和分段函数来精确描述电荷分布,确保模型的准确性。接着,讨论了网格划分的技术细节,强调了在电荷突变区域使用边界层网格和自适应细化的重要性。然后,针对求解器设置提出了改进建议,如采用牛顿迭代法和调整阻尼因子,以提高收敛性和稳定性。此外,还探讨了后处理阶段的数据提取和可视化方法,如计算电场强度、绘制电场矢量图以及处理电场奇异值。最后,通过参数扫描实验展示了摩擦层厚度对输出电压的影响,并强调了电荷守恒检查的重要性。 适合人群:从事纳米摩擦发电机研究的科研人员和技术开发者,尤其是熟悉COMSOL软件的用户。 使用场景及目标:适用于需要深入理解和优化纳米摩擦发电机性能的研究项目。主要目标是帮助研究人员掌握如何在COMSOL中构建和优化TENG模型,从而更好地理解电荷密度与电场之间的关系及其对发电效率的影响。 其他说明:文中提供了大量实用的操作技巧和注意事项,有助于避免常见错误并提升模拟精度。同时,通过具体的实例演示,使读者能够快速上手并应用于实际研究中。

    ### 电力系统基于RNN的短期电力负荷预测模型设计:双向多尺度LSTM与残差多尺度RNN的应用

    内容概要:本文针对短期电力负荷预测,提出基于双向多尺度跳跃长短期记忆网络(BMS-LSTM)和残差多尺度循环神经网络(Res-MSRNN)的两种新型预测模型。BMS-LSTM通过双向结构和多尺度跳跃连接,有效提取电力负荷数据的双向及多尺度特征;Res-MSRNN利用空间卷积和残差网络机制,克服了全连接层融合多尺度特征的不足。实验结果表明,这两种模型在单日及周电力负荷预测中,相比RNN、LSTM、GRU等传统模型,均展现出更高的预测精度、稳定性和鲁棒性。研究为电力系统的安全可靠运行、资源优化配置及智能化发展提供了有力支持。 适合人群:从事电力系统规划、运行与管理的专业人员,以及对深度学习应用于电力负荷预测感兴趣的科研人员和工程师。 使用场景及目标:①为电力企业在发电计划制定、电网调度与建设规划以及电力市场交易决策等方面提供高精度的负荷预测数据;②提升电力系统运行的安全性与可靠性,优化电力资源配置与降低成本;③推动电力市场的健康发展,促进电力行业的智能化转型。 其他说明:尽管BMS-LSTM和Res-MSRNN模型在预测性能上表现出色,但其复杂结构导致计算资源需求增加。未来研究可进一步探索模型压缩与加速技术,降低模型复杂度,提高其在资源受限环境下的实用性。此外,还需持续拓展对电力负荷影响因素的研究范围,结合大数据分析技术,挖掘更多潜在的影响因素,以进一步提升模型的预测能力。

    基于谓词逻辑的归结原理研究.pdf

    基于谓词逻辑的归结原理研究.pdf

    Rust无服务器架构实战:AWSLambda集成完整指南.pdf

    文档支持目录章节跳转同时还支持阅读器左侧大纲显示和章节快速定位,文档内容完整、条理清晰。文档内所有文字、图表、函数、目录等元素均显示正常,无任何异常情况,敬请您放心查阅与使用。文档仅供学习参考,请勿用作商业用途。 Rust 以内存安全、零成本抽象和并发高效的特性,重塑编程体验。无需垃圾回收,却能通过所有权与借用检查机制杜绝空指针、数据竞争等隐患。从底层系统开发到 Web 服务构建,从物联网设备到高性能区块链,它凭借出色的性能和可靠性,成为开发者的全能利器。拥抱 Rust,解锁高效、安全编程新境界!

Global site tag (gtag.js) - Google Analytics