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

连接池c3p0 ,Proxool ,Druid ,Tomcat Jdbc Pool对比测试

 
阅读更多

        这次所要做的测试是比较几种我们常用的数据库连接池的性能,他们分别是:c3p0 ,Proxool ,Druid ,Tomcat Jdbc Pool这四种,测试将采用统一的参数配置力求比较“公平”的体现统一水平下几种连接池的不同,有网友回复说测试不公平会互相干扰,那我就把代码分开,代码是死的人是活的,做事情不动脑只能吃别人剩下的,世界上没有绝对公平的事情,我在此只提供了一个思路,更多的测试还需要你自己去完成。

 

        1.创建类TestDAO,封装统一的查询方法 :

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class TestDAO {

    private final static String sql = "SELECT * FROM USER u WHERE u.USR_ID=9999";

    public void query(Connection conn) {
        try {
            Statement st = conn.createStatement();
            ResultSet result = st.executeQuery(sql);
            result.close();
            st.close();
            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
}

 

 

        2.创建测试类TestMain,其中包含:统一参数配置属性、获取各种连接池数据源方法、各种数据源调用方法等,下面分别是各种数据源的测试Main方法,开始测试之前做100次查询操作以初始化连接池并起到稳定测试结果作用:

 

        (1)c3p0测试代码:

import java.beans.PropertyVetoException;
import java.io.IOException;
import java.sql.SQLException;
import com.mchange.v2.c3p0.ComboPooledDataSource;

public class C3p0Test {

    // 数据库驱动名称
    final static String driver = "com.mysql.jdbc.Driver";
    // 数据库连接地址
    final static String jdbcUrl = "jdbc:mysql://192.168.0.1:3306/test";
    // 数据库用户名
    final static String user = "dba";
    // 数据库密码
    final static String passwd = "dba";
    // 连接池初始化大小
    final static int initialSize = 5;
    // 连接池最小空闲
    final static int minPoolSize = 10;
    // 连接池最大连接数量
    final static int maxPoolSize = 50;
    // 最小逐出时间,100秒
    final static int maxIdleTime = 100000;
    // 连接失败重试次数
    final static int retryAttempts = 10;
    // 当连接池连接耗尽时获取连接数
    final static int acquireIncrement = 5;
    // c3p0数据源
    final static ComboPooledDataSource c3p0DataSource = getC3p0DataSource();

    // 查询次数
    final static int count = 10;

    /**
     * 测试方式: 每种数据源配置信息尽量相同,以求结果更加准确
     * 每种数据源做10次、100次、500次、1000次、2000次、4000次、8000次查询操作 每种查询重复100次,查看100次执行时间的波动图
     * @param args
     * @throws IOException
     * @throws SQLException
     */
    public static void main(String[] args) throws IOException, SQLException {

        TestDAO testDAO = new TestDAO();
        System.out.println("查询次数为:" + count);
        System.out.println();
        System.out.println("==========================c3p0 测试开始==========================");
        // 测试c3p0
        for (int i = 0; i < 100; i++) {
            queryC3p0(testDAO, c3p0DataSource, count);
        }
        System.out.println("==========================c3p0 测试结束==========================");
    }

    /**
     * c3p0测试
     * @param testDAO
     * @param ds
     * @param count
     * @throws SQLException
     */
    public static void queryC3p0(TestDAO testDAO, ComboPooledDataSource ds, int count) throws SQLException {
        // 查询100次以初始化连接池
        for (int i = 0; i < 100; i++) {
            testDAO.query(ds.getConnection());
        }
        // 开始时间
        long startMillis = System.currentTimeMillis();
        // 循环查询
        for (int i = 0; i < count; i++) {
            testDAO.query(ds.getConnection());
        }
        // 结束时间
        long endMillis = System.currentTimeMillis();
        // 输出结束时间
        System.out.println(endMillis - startMillis);
    }

    /**
     * 获取c3p0数据源
     * @throws PropertyVetoException
     */
    public static ComboPooledDataSource getC3p0DataSource() {
        // 设置参数
        ComboPooledDataSource cpds = new ComboPooledDataSource();
        try {
            cpds.setDriverClass(driver);
        } catch (PropertyVetoException e) {
            e.printStackTrace();
        }
        cpds.setJdbcUrl(jdbcUrl);
        cpds.setUser(user);
        cpds.setPassword(passwd);
        cpds.setInitialPoolSize(initialSize);
        cpds.setMinPoolSize(minPoolSize);
        cpds.setMaxPoolSize(maxPoolSize);
        cpds.setMaxIdleTime(maxIdleTime);
        cpds.setAcquireRetryAttempts(retryAttempts);
        cpds.setAcquireIncrement(acquireIncrement);
        cpds.setTestConnectionOnCheckin(false);
        cpds.setTestConnectionOnCheckout(false);
        return cpds;
    }
}

 

 

        (2)Proxool测试代码: 

import java.io.IOException;
import java.sql.SQLException;
import org.logicalcobwebs.proxool.ProxoolDataSource;

public class ProxoolTest {

    // 数据库驱动名称
    final static String driver = "com.mysql.jdbc.Driver";
    // 数据库连接地址
    final static String jdbcUrl = "jdbc:mysql://192.168.0.1:3306/test";
    // 数据库用户名
    final static String user = "dba";
    // 数据库密码
    final static String passwd = "dba";
    // 连接池初始化大小
    final static int initialSize = 5;
    // 连接池最小空闲
    final static int minPoolSize = 10;
    // 连接池最大连接数量
    final static int maxPoolSize = 50;
    // 最小逐出时间,100秒
    final static int maxIdleTime = 100000;
    // 连接失败重试次数
    final static int retryAttempts = 10;
    // 当连接池连接耗尽时获取连接数
    final static int acquireIncrement = 5;
    // Proxool数据源
    final static ProxoolDataSource proxoolDataSource = getProxoolDataSource();
    // 查询次数
    final static int count = 10;

    /**
     * 测试方式: 每种数据源配置信息尽量相同,以求结果更加准确
     * 每种数据源做10次、100次、500次、1000次、2000次、4000次、8000次查询操作 每种查询重复100次,查看100次执行时间的波动图
     * @param args
     * @throws IOException
     * @throws SQLException
     */
    public static void main(String[] args) throws IOException, SQLException {

        TestDAO testDAO = new TestDAO();
        System.out.println("查询次数为:" + count);
        System.out.println();
        System.out.println("==========================Proxool 测试开始==========================");
        // 测试Proxool
        for (int i = 0; i < 100; i++) {
            queryProxxool(testDAO, proxoolDataSource, count);
        }
        System.out.println("==========================Proxool 测试结束==========================");
    }

    /**
     * Proxxool测试
     * @param testDAO
     * @param ds
     * @param count
     * @throws SQLException
     */
    public static void queryProxxool(TestDAO testDAO, ProxoolDataSource ds, int count) throws SQLException {
        // 查询100次以初始化连接池
        for (int i = 0; i < 100; i++) {
            testDAO.query(ds.getConnection());
        }
        // 开始时间
        long startMillis = System.currentTimeMillis();
        // 循环查询
        for (int i = 0; i < count; i++) {
            testDAO.query(ds.getConnection());
        }
        // 结束时间
        long endMillis = System.currentTimeMillis();
        // 输出结束时间
        System.out.println(endMillis - startMillis);
    }

    /**
     * 获取Proxool数据源
     * @return
     */
    public static ProxoolDataSource getProxoolDataSource() {
        ProxoolDataSource pds = new ProxoolDataSource();
        pds.setAlias("mysql");
        pds.setUser(user);
        pds.setPassword(passwd);
        pds.setDriverUrl(jdbcUrl);
        pds.setDriver(driver);
        pds.setMaximumActiveTime(maxIdleTime);
        pds.setMaximumConnectionCount(maxPoolSize);
        pds.setMinimumConnectionCount(initialSize);
        pds.setPrototypeCount(minPoolSize);
        pds.setTestBeforeUse(false);
        pds.setTestAfterUse(false);
        return pds;
    }

}

 

 

        (3)Druid测试代码:

import java.io.IOException;
import java.sql.SQLException;
import com.alibaba.druid.pool.DruidDataSource;

public class DruidTest {

    // 数据库驱动名称
    final static String driver = "com.mysql.jdbc.Driver";
    // 数据库连接地址
    final static String jdbcUrl = "jdbc:mysql://192.168.0.1:3306/test";
    // 数据库用户名
    final static String user = "dba";
    // 数据库密码
    final static String passwd = "dba";
    // 连接池初始化大小
    final static int initialSize = 5;
    // 连接池最小空闲
    final static int minPoolSize = 10;
    // 连接池最大连接数量
    final static int maxPoolSize = 50;
    // 最小逐出时间,100秒
    final static int maxIdleTime = 100000;
    // 连接失败重试次数
    final static int retryAttempts = 10;
    // 当连接池连接耗尽时获取连接数
    final static int acquireIncrement = 5;
    // Druid数据源
    final static DruidDataSource druidDataSource = getDruidDataSource();
    // 查询次数
    final static int count = 10;

    /**
     * 测试方式: 每种数据源配置信息尽量相同,以求结果更加准确
     * 每种数据源做10次、100次、500次、1000次、2000次、4000次、8000次查询操作 每种查询重复100次,查看100次执行时间的波动图
     * @param args
     * @throws IOException
     * @throws SQLException
     */
    public static void main(String[] args) throws IOException, SQLException {

        TestDAO testDAO = new TestDAO();
        System.out.println("查询次数为:" + count);
        System.out.println();
        System.out.println("==========================Druid 测试开始==========================");
        // 测试Druid
        for (int i = 0; i < 100; i++) {
            queryDruid(testDAO, druidDataSource, count);
        }
        System.out.println("==========================Druid 测试结束==========================");
    }

    /**
     * Druid测试
     * @param testDAO
     * @param ds
     * @param count
     * @throws SQLException
     */
    public static void queryDruid(TestDAO testDAO, DruidDataSource ds, int count) throws SQLException {
        // 查询100次以初始化连接池
        for (int i = 0; i < 100; i++) {
            testDAO.query(ds.getConnection());
        }
        // 开始时间
        long startMillis = System.currentTimeMillis();
        // 循环查询
        for (int i = 0; i < count; i++) {
            testDAO.query(ds.getConnection());
        }
        // 结束时间
        long endMillis = System.currentTimeMillis();
        // 输出结束时间
        System.out.println(endMillis - startMillis);
    }

    /**
     * 获取Druid数据源
     * @return
     */
    public static DruidDataSource getDruidDataSource() {
        DruidDataSource dds = new DruidDataSource();
        dds.setUsername(user);
        dds.setUrl(jdbcUrl);
        dds.setPassword(passwd);
        dds.setDriverClassName(driver);
        dds.setInitialSize(initialSize);
        dds.setMaxActive(maxPoolSize);
        dds.setMaxWait(maxIdleTime);
        dds.setTestWhileIdle(false);
        dds.setTestOnReturn(false);
        dds.setTestOnBorrow(false);
        return dds;
    }

}

 

 

        (4)Tomcat Jdbc Pool测试代码:

import java.io.IOException;
import java.sql.SQLException;
import org.apache.tomcat.jdbc.pool.DataSource;

public class TomcatTest {

    // 数据库驱动名称
    final static String driver = "com.mysql.jdbc.Driver";
    // 数据库连接地址
    final static String jdbcUrl = "jdbc:mysql://192.168.0.1:3306/test";
    // 数据库用户名
    final static String user = "dba";
    // 数据库密码
    final static String passwd = "dba";
    // 连接池初始化大小
    final static int initialSize = 5;
    // 连接池最小空闲
    final static int minPoolSize = 10;
    // 连接池最大连接数量
    final static int maxPoolSize = 50;
    // 最小逐出时间,100秒
    final static int maxIdleTime = 100000;
    // 连接失败重试次数
    final static int retryAttempts = 10;
    // 当连接池连接耗尽时获取连接数
    final static int acquireIncrement = 5;
    // Tomcat Jdbc Pool数据源
    final static DataSource tomcatDataSource = getTomcatDataSource();
    // 查询次数
    final static int count = 100;

    /**
     * 测试方式: 每种数据源配置信息尽量相同,以求结果更加准确
     * 每种数据源做10次、100次、500次、1000次、2000次、4000次、8000次查询操作 每种查询重复100次,查看100次执行时间的波动图
     * @param args
     * @throws IOException
     * @throws SQLException
     */
    public static void main(String[] args) throws IOException, SQLException {

        TestDAO testDAO = new TestDAO();
        System.out.println("查询次数为:" + count);
        System.out.println();
        System.out.println("==========================Tomcat Jdbc Pool 测试开始==========================");
        // 测试Tomcat Jdbc Pool
        for (int i = 0; i < 100; i++) {
            queryTomcatJDBC(testDAO, tomcatDataSource, count);
        }
        System.out.println("==========================Tomcat Jdbc Pool 测试结束==========================");
    }

    /**
     * Tomcat Jdbc Pool测试
     * @param testDAO
     * @param ds
     * @param count
     * @throws SQLException
     */
    public static void queryTomcatJDBC(TestDAO testDAO, DataSource ds, int count) throws SQLException {
        // 查询100次以初始化连接池
        for (int i = 0; i < 100; i++) {
            testDAO.query(ds.getConnection());
        }
        // 开始时间
        long startMillis = System.currentTimeMillis();
        // 循环查询
        for (int i = 0; i < count; i++) {
            testDAO.query(ds.getConnection());
        }
        // 结束时间
        long endMillis = System.currentTimeMillis();
        // 输出结束时间
        System.out.println(endMillis - startMillis);
    }

    /**
     * 获取Apache tomcat jdbc pool数据源
     * @return
     */
    public static DataSource getTomcatDataSource() {
        DataSource ds = new DataSource();
        ds.setUrl(jdbcUrl);
        ds.setUsername(user);
        ds.setPassword(passwd);
        ds.setDriverClassName(driver);
        ds.setInitialSize(initialSize);
        ds.setMaxIdle(minPoolSize);
        ds.setMaxActive(maxPoolSize);
        ds.setTestWhileIdle(false);
        ds.setTestOnBorrow(false);
        ds.setTestOnConnect(false);
        ds.setTestOnReturn(false);
        return ds;
    }
}

               

 

 

        3.将测试结果粘贴到excel中,生成图表进行对比,可以很直观的看出几种数据源的性能差异,本文底部有此次测试的结果文档。

 

 

        以下就是此次测试结果(本结果只供参考,更具体更准确的测试可以自行进行):

 

        1.测试次数为10次时:



        平均用时(单位:毫秒):

c3p0 32.26
Proxool 33.42
Druid 30.43
Tomcat Jdbc Pool 37.61

 

 

        2.测试次数为100次时:



        平均用时(单位:毫秒):

c3p0 409.94
Proxool 447.49
Druid 382.7
Tomcat Jdbc Pool 386.3

 

 

        3.测试次数为500次时:


        平均用时(单位:毫秒):

c3p0 1700.95
Proxool 2053.85
Druid 1777.36
Tomcat Jdbc Pool 1749.02

 

 

        4.测试次数为1000次时:



        平均用时(单位:毫秒):

c3p0  3549.29
Proxool  3435.8
Druid  3167.59
Tomcat Jdbc Pool  3162.25

 

        因为测试耗时很长,所以我只做到了1000次查询测试,感兴趣的朋友可以继续更大规模的测试或修改相应参数来符合项目自身情况,这里不比去追究测试数据的准确性,比较测试程度还不够,且存在很大的偶然性,大家可以修改以上代码进行更精准的测试,只需要将数据导入到本文末尾的excel表格中即可生成相应测试图表。

        很多人总是会回复在问“你的测试准不准啊?”,“你的测试一点都不准!”等等,其实我想说的是:不要太在意别人的结果,重要的是自己去做!

 

  • 大小: 98.5 KB
  • 大小: 104.2 KB
  • 大小: 79.7 KB
  • 大小: 75.3 KB
9
4
分享到:
评论
7 楼 ssy341 2013-10-11  
支持一个,方法很全面,可以参考,感觉现在用druid的还是比较少,文档不是很全面
6 楼 iskp 2013-08-06  
g21121 写道
iskp 写道
楼主,明显改过这篇文章,昨天的测试结果让我很意外,今天的结果还算是正常。


这种测试其实存在很大偶然性,比较片面


主要是测试的差距有点偏大,也许是测试用例的设计不一样
5 楼 g21121 2013-08-06  
iskp 写道
楼主,明显改过这篇文章,昨天的测试结果让我很意外,今天的结果还算是正常。


这种测试其实存在很大偶然性,比较片面
4 楼 iskp 2013-08-06  
楼主,明显改过这篇文章,昨天的测试结果让我很意外,今天的结果还算是正常。

3 楼 Tyrion 2013-08-05  
g21121 写道
Tyrion 写道
Druid是阿里系的吧,据说性能方面超过了其它同类产品,博主是生产环境中用过?

是阿里巴巴的,生产中没有用到过,我也是听“据说性能非常好”才做测试的,图片里面绿色的就是Druid,某些方面性能还是可以的,但开源项目文档方面非常差


前段时间看了Druid作者放在github上的介绍,对于使用者最主要的担心是Druid目前太小众,出了问题只能找阿里的人回答或自己研究源码,对于有项目进度压力的情况下这个肯定不是首选。
2 楼 g21121 2013-08-05  
Tyrion 写道
Druid是阿里系的吧,据说性能方面超过了其它同类产品,博主是生产环境中用过?

是阿里巴巴的,生产中没有用到过,我也是听“据说性能非常好”才做测试的,图片里面绿色的就是Druid,某些方面性能还是可以的,但开源项目文档方面非常差
1 楼 Tyrion 2013-08-05  
Druid是阿里系的吧,据说性能方面超过了其它同类产品,博主是生产环境中用过?

相关推荐

    JAVA数据库连接池(C3P0,Druid,JNDI ,DBCP,Proxool,BoneCP)

    本文将详细介绍几个常见的Java数据库连接池实现:C3P0、Druid、JNDI、DBCP、Proxool以及BoneCP,并结合Spring+MyBatis+maven环境下的应用示例进行解析。 1. C3P0: C3P0是一个开源的JDBC连接池,它实现了数据源和...

    Java Spring常用高性能连接池以及属性

    * C3P0比较耗费资源,效率方面可能要低一点。 * DBCP在实践中存在BUG,在某些种情会产生很多空连接不能释放,Hibernate3.0已经放弃了对其的支持。 * Proxool的负面评价较少,现在比较推荐它,而且它还提供即时监控...

    Java中常用的数据库连接池[定义].pdf

    - c3p0:这是一个JDBC连接池,集成在Hibernate中,支持JDBC3和JDBC2扩展规范。c3p0提供了连接和Statement的池化,具备自动检测失效连接的功能。 - Druid:阿里巴巴开发的数据库连接池,不仅是一个连接池,还包括...

    基于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技术将分割出的文字转换为可读字符串。文中还讨论了针对不同国家车牌特色的个性化处理方法以及提高识别精度的各种技巧。 适合人群:对图像处理和车牌识别感兴趣的科研人员、学生及开发者。 使用场景及目标:适用于希望深入了解车牌识别技术原理并尝试构建自己的车牌识别系统的个人或团队。目标是在常见条件下达到较高的车牌识别成功率。 其他说明:尽管传统算法能够满足大部分日常需求,但在极端环境下(如恶劣天气)仍存在局限性,因此文中也提到了进一步优化的方向,例如引入深度学习模型等。

Global site tag (gtag.js) - Google Analytics