当前位置: 首页 > news >正文

【模式识别】探秘分类奥秘:最近邻算法解密与实战

🌈个人主页:Sarapines Programmer
🔥 系列专栏:《模式之谜 | 数据奇迹解码》
⏰诗赋清音:云生高巅梦远游, 星光点缀碧海愁。 山川深邃情难晤, 剑气凌云志自修。

目录

🌌1 初识模式识别

🌌2 最近邻法

🌍2.1 研究目的

🌍2.2 研究环境

🌍2.3 研究内容

🌕2.3.1 算法原理介绍

🌕2.3.2 实验步骤

🌕2.3.3 实验结果

🌍2.4 研究体会

📝总结


🌌1 初识模式识别

模式识别是一种通过对数据进行分析和学习,从中提取模式并做出决策的技术。这一领域涵盖了多种技术和方法,可用于处理各种类型的数据,包括图像、语音、文本等。以下是一些常见的模式识别技术:

  1. 图像识别

    • 计算机视觉:使用计算机和算法模拟人类视觉,使机器能够理解和解释图像内容。常见的应用包括人脸识别、物体检测、图像分类等。

    • 卷积神经网络(CNN):一种专门用于图像识别的深度学习模型,通过卷积层、池化层等结构提取图像中的特征。

  2. 语音识别

    • 自然语言处理(NLP):涉及对人类语言进行处理和理解的技术。包括文本分析、情感分析、命名实体识别等。

    • 语音识别:将语音信号转换为文本,使机器能够理解和处理语音命令。常见应用包括语音助手和语音搜索。

  3. 模式识别在生物医学领域的应用

    • 生物特征识别:包括指纹识别、虹膜识别、基因序列分析等,用于生物医学研究和安全身份验证。

    • 医学图像分析:利用模式识别技术分析医学影像,如MRI、CT扫描等,以辅助医生进行诊断。

  4. 时间序列分析

    • 时间序列模式识别:对时间序列数据进行建模和分析,用于预测趋势、检测异常等。在金融、气象、股票市场等领域有广泛应用。
  5. 数据挖掘和机器学习

    • 聚类算法:将数据集中的相似对象分组,常用于无监督学习,如K均值聚类。

    • 分类算法:建立模型来对数据进行分类,如决策树、支持向量机等。

    • 回归分析:用于建立输入和输出之间的关系,用于预测数值型结果。

    • 深度学习:通过多层神经网络学习数据的表示,适用于处理大规模和复杂的数据。

  6. 模式识别在安全领域的应用

    • 行为分析:监测和识别异常行为,如入侵检测系统。

    • 生物特征识别:用于身份验证和访问控制,如指纹、面部识别。

这些技术通常不是孤立存在的,而是相互交叉和融合的,以解决更复杂的问题。在实际应用中,根据具体的问题和数据特点选择合适的模式识别技术是至关重要的。


🌌2 最近邻法

🌍2.1 研究目的

1. 探究最近邻法的基本算法。

2. 了解最近邻法在数据分类问题中的应用。

3. 通过实践提高对最近邻法的理解与掌握。


🌍2.2 研究环境

  1. C++编程语言及其相关库

    • 语言支持: VSCode具备强大的C++语言支持,提供代码高亮、自动完成等功能,使得编码更加高效。
    • Eigen库: 作为线性代数的重要工具,Eigen库被集成用于进行高效的线性代数运算,为数学计算提供了强大的支持。
  2. OpenCV库

    • 图像处理: OpenCV库作为计算机视觉领域的重要工具,为图像处理和可视化提供了广泛的功能。包括图像读取、处理、特征提取等一系列操作,为图像相关的应用提供了基础支持。
    • 可视化: OpenCV还支持直观的图像可视化,使开发者能够直观地观察图像处理的效果,有助于调试和优化。
  3. C++编译器配置

    • GCC配置: 在使用VSCode进行C++开发时,确保已配置好C++编译器,常用的是GNU Compiler Collection(GCC)。正确的配置保证了代码的正确编译和执行。
  4. 硬件环境

    • 计算资源: 为了处理图像数据,需要充足的计算资源,包括足够的内存和强大的CPU/GPU。这保障了对大规模图像数据进行高效处理和运算。
    • 内存管理: 在处理大规模图像数据时,合理的内存管理变得至关重要,以防止内存溢出和提高程序运行效率。

🌍2.3 研究内容

🌕2.3.1 算法原理介绍

最近邻算法(K-Nearest Neighbors,简称KNN)是一种基于实例的监督学习算法,用于解决分类和回归问题。其算法原理如下:

分类问题的 KNN 算法原理:

  1. 数据集准备: 给定一个已标记的训练数据集,其中每个样本都有一个已知的类别标签。

  2. 距离度量: 定义样本间的距离度量方式,通常使用欧氏距离(Euclidean distance)或其他距离度量方法。欧氏距离是最常见的选择,计算两个样本点之间的直线距离。

  3. 选择K值: 确定一个整数K,表示在进行预测时将考虑的最近邻的数量。

  4. 预测过程:

    • 对于每个新的未标记样本点,计算它与训练集中所有样本点的距离。

    • 选择与新样本距离最近的K个训练样本。

    • 统计这K个训练样本中各类别的数量。

    • 将新样本分配给K个最近邻中占比最多的类别作为预测结果。

回归问题的 KNN 算法原理:

  1. 数据集准备: 同样,给定一个已标记的训练数据集,每个样本有一个已知的数值型输出。

  2. 距离度量: 采用距离度量方式,通常使用欧氏距离或其他距离度量方法。

  3. 选择K值: 同样,确定K值,表示在进行预测时将考虑的最近邻的数量。

  4. 预测过程:

    • 对于每个新的未标记样本点,计算它与训练集中所有样本点的距离。

    • 选择与新样本距离最近的K个训练样本。

    • 将这K个训练样本的输出值进行平均(或加权平均),作为新样本的预测输出值。

算法特点:

  • 非参数性: KNN 是一种非参数学习算法,它不对模型进行假设,而是根据训练数据动态地进行决策。

  • 计算复杂度: KNN 的主要计算复杂度在于找到最近邻的过程,尤其是在高维空间或大型数据集上。为了提高效率,可以使用树结构(如KD树)等数据结构来加速搜索过程。

  • 选择 K 值: K 的选择对 KNN 的性能有重要影响。较小的K值会增加模型的复杂度,可能对噪声敏感;较大的K值会使模型更稳定,但可能忽略了局部特征。

KNN 算法的简单性和直观性使其成为一个常用的基准算法,但在大型数据集或高维空间中可能面临计算效率的问题。


🌕2.3.2 实验步骤

  1. 数据准备:在实验中,我们选用了经典的鸢尾花数据集作为样本数据。该数据集包含三个类别,每个类别有四个特征,是一个适合用最近邻法进行分类的示例。
  2. 最近邻法算法实现:使用scikit-learn库中的KNeighborsClassifier类,基于最近邻法实现一个分类器。设置合适的参数,如近邻数(k值),并进行模型训练。
  3. 数据加载与划分
  4. 最近邻法模型训练
  5. 预测与评估

C语言代码:

// zjlsort.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include "math.h"
#include "pattern.h"
#include "vector.h"int GetSort(unsigned char dat[4][8][8][60],unsigned char x[8][60])
{int i,k,cj,m;int bcha,min_bcha;int cj_num[32];for (cj=0;cj<32;cj++) cj_num[cj]=0;for (k=0;k<8;k++) {for (cj=0;cj<32;cj++) {bcha=0;for (m=0;m<60;m++) {bcha+=abs(dat[cj/8][cj%8][k][m]-x[k][m]);}if (cj==0) {min_bcha=bcha;i=0;} else {if (bcha<min_bcha) {min_bcha=bcha;i=cj;}}}i=(i/8)*8+i%4;cj_num[i]++;}/*for (m=0;m<60;m++) {for (cj=0;cj<32;cj++) {bcha=0;for (k=0;k<8;k++) {bcha+=abs(dat[cj/8][cj%8][k][m]-x[k][m]);}if (cj==0) {min_bcha=bcha;i=0;} else {if (bcha<min_bcha) {min_bcha=bcha;i=cj;}}}i=(i/8)*8+i%4;cj_num[i]++;}*/int av,bav,q2,bq2,xq;int xg,max_xg;for (k=0;k<8;k++) {for (cj=0;cj<32;cj++) {av=0;bav=0;for (m=0;m<60;m++) {bav+=dat[cj/8][cj%8][k][m];av+=x[k][m];}av/=60;bav/=60;q2=0;bq2=0;xq=0;for (m=0;m<60;m++) {bq2+=(dat[cj/8][cj%8][k][m]-bav)*(dat[cj/8][cj%8][k][m]-bav);q2+=(x[k][m]-av)*(x[k][m]-av);xq+=(x[k][m]-av)*(dat[cj/8][cj%8][k][m]-bav);}bq2/=60;q2/=60;xq/=60;xg=100*xq/sqrt((double)bq2*q2);if (cj==0) {max_xg=xg;i=0;} else {if (xg>max_xg) {max_xg=xg;i=cj;}}}i=(i/8)*8+i%4;cj_num[i]++;}for (k=0;k<8;k++) {for (cj=0;cj<32;cj++) {bcha=0;for (m=2;m<60;m++) {bcha+=abs(dat[cj/8][cj%8][k][m]-dat[cj/8][cj%8][k][m-2]-x[k][m]+x[k][m-2]);}if (cj==0) {min_bcha=bcha;i=0;} else {if (bcha<min_bcha) {min_bcha=bcha;i=cj;}}}i=(i/8)*8+i%4;cj_num[i]++;}for (k=0;k<8;k++) {for (cj=0;cj<32;cj++) {bcha=0;for (m=4;m<60;m++) {bcha+=abs(dat[cj/8][cj%8][k][m]-dat[cj/8][cj%8][k][m-3]-x[k][m]+x[k][m-3]);}if (cj==0) {min_bcha=bcha;i=0;} else {if (bcha<min_bcha) {min_bcha=bcha;i=cj;}}}i=(i/8)*8+i%4;cj_num[i]++;}k=cj_num[0];i=0;for (cj=1;cj<32;cj++) {if (cj_num[cj]>k) {k=cj_num[cj];i=cj;}}return i;
}int Get_Cor(unsigned char dat[4][8][8][60],unsigned char x[8][60])
{int av,bav,q2,bq2,xq;int xg,max_xg,sum_xg;int cj,i,k,m,l,c;max_xg=0;c=0;for (l=-1;l<2;l++) {for (cj=0;cj<32;cj++) {sum_xg=0;for (k=0;k<8;k++) {av=0;bav=0;for (m=1;m<59;m++) {bav+=dat[cj/8][cj%8][k][m];av+=x[k][m+l];}av/=58;bav/=58;q2=0;bq2=0;xq=0;for (m=1;m<59;m++) {bq2+=(dat[cj/8][cj%8][k][m]-bav)*(dat[cj/8][cj%8][k][m]-bav);q2+=(x[k][m+l]-av)*(x[k][m+l]-av);xq+=(x[k][m+l]-av)*(dat[cj/8][cj%8][k][m]-bav);}bq2/=58;q2/=58;xq/=58;xg=100*xq/sqrt((double)bq2*q2);sum_xg+=xg;}if (sum_xg>max_xg) {max_xg=sum_xg;i=cj;c=l;}}}return i;
}int GetSort_2(unsigned char dat[4][8][8][60],unsigned char x[8][60])
{int i,k,cj,m;int bcha,min_bcha,sum_bcha;int min_i,max_i;for (cj=0;cj<32;cj++) {sum_bcha=0;for (k=0;k<8;k++) {bcha=0;for (m=0;m<60;m++) {bcha+=abs(dat[cj/8][cj%8][k][m]-x[k][m]);}bcha/=60;sum_bcha+=bcha;}if (cj==0) {min_bcha=sum_bcha;i=0;} else {if (sum_bcha<min_bcha) {min_bcha=sum_bcha;i=cj;}}}min_i=(i/8)*8+i%4;int av,bav,q2,bq2,xq;int xg,max_xg,sum_xg;for (cj=0;cj<32;cj++) {sum_xg=0;for (k=0;k<8;k++) {av=0;bav=0;for (m=0;m<60;m++) {bav+=dat[cj/8][cj%8][k][m];av+=x[k][m];}av/=60;bav/=60;q2=0;bq2=0;xq=0;for (m=0;m<60;m++) {bq2+=(dat[cj/8][cj%8][k][m]-bav)*(dat[cj/8][cj%8][k][m]-bav);q2+=(x[k][m]-av)*(x[k][m]-av);xq+=(x[k][m]-av)*(dat[cj/8][cj%8][k][m]-bav);}bq2/=60;q2/=60;xq/=60;xg=100*xq/sqrt((double)bq2*q2);sum_xg+=xg;}if (cj==0) {max_xg=sum_xg;i=0;} else {if (sum_xg>max_xg) {max_xg=sum_xg;i=cj;}}}max_i=(i/8)*8+i%4;if (min_i==max_i) return min_i;else {return Get_Cor(dat,x);}
}int main(int argc, char* argv[])
{int sort,i,j,k;
/*for (k=0;k<10;k++) {for (sort=0;sort<10;sort++) {for (i=0;i<CNUM;i++) {j=GetSort(dat[k],dat[sort][i/8][i%8]);j=(j/8)*8+j%4;if (j!=((i/8)*8+i%4)) {printf("k=%d\n",k);printf("sort=%d\n",sort);printf("err:i=%d\n",i);}} //end of i} // end of sort}*/for (k=0;k<10;k++) {for (sort=0;sort<10;sort++) {for (i=0;i<CNUM;i++) {j=GetSort_2(dat[k],dat[sort][i/8][i%8]);j=(j/8)*8+j%4;if (j!=((i/8)*8+i%4)) {printf("k=%d\n",k);printf("sort=%d\n",sort);printf("err:i=%d\n",i);}} //end of i} // end of sort}return 0;
}

程序分析:

这段程序是一个基于图像模式识别的排序算法。它的主要思路是通过计算两个图像之间的差异,然后根据差异的大小进行排序。程序中使用了一些复杂的计算,包括绝对值之和、均值、方差等,同时还涉及到一些图像处理的操作。以下是对程序的详细分析:

  1. 数据结构:

    • unsigned char dat[4][8][8][60]: 这是一个四维数组,表示图像数据。第一维度表示数据集数量(4个),第二维和第三维表示图像的行和列(8x8的图像),第四维表示图像的通道(60个通道)。
    • unsigned char x[8][60]: 这是一个二维数组,表示待排序的图像数据。
  2. GetSort函数:

    • 该函数接收一个数据集 dat 和一个待排序的图像 x,然后通过计算图像之间的差异,确定一个最相似的数据集。具体过程包括:
      • 计算每个通道上的绝对值之和,寻找最小的差异。
      • 计算每个通道上的均值和方差,通过一定方式计算相似性,得到最大相似性。
      • 计算两个相邻像素的差异,找到最小差异。
      • 以上三种差异的综合来决定最相似的数据集。
  3. Get_Cor函数:

    • 该函数计算图像之间的相似性,与 GetSort 函数的一部分功能重复。它通过计算通道内像素的均值、方差等,找到相似性最高的数据集。
  4. GetSort_2函数:

    • 该函数也是用于获取最相似的数据集,与 GetSort 函数相似,但采用了一些不同的差异度量方法。最终决策是综合了几种方法,如果某一种方法找到的结果与其他不同,则调用 Get_Cor 函数进一步判断。
  5. 主函数main:

    • 主函数对数据集进行测试,通过调用 GetSort_2 函数,检查算法在不同数据集和图像之间的排序效果。在两个嵌套循环中,程序输出任何排序错误的情况。

总体而言,这个程序主要用于比较不同图像数据集之间的相似性,通过计算差异度量,找到最相似的数据集。在实际应用中,可能需要根据具体问题调整和优化算法,确保其在特定情境下的效果。


🌕2.3.3 实验结果


🌍2.4 研究体会

  1. 近邻数选择关键性影响: 通过实际操作,我深切认识到在最近邻法中,近邻数的选择对模型性能至关重要。过大或过小的近邻数均可能导致模型在实际应用中表现不佳,突显了参数调整在算法性能优化中的关键性作用。

  2. 算法选择与数据特性关系深刻领悟: 在不同数据集上的实验让我更加深刻地理解了算法选择与数据特性之间的密切关系。不同数据集对最近邻法的适应性有不同要求,因此我认识到在实际问题中灵活调整算法参数的重要性,为未来决策提供了更多思考空间,使我在算法选择上更为慎重和明智。

  3. 分类边界可视化提升模型理解: 通过可视化实验结果,我深入了解了最近邻法在不同类别之间划定分类边界的方式。这不仅增进了我对模型行为的理解,还为模型的可解释性提供了更深刻的认识。对分类边界的直观把握使我能够更自信地应用最近邻法解决实际问题,并更好地沟通模型的结果与决策。


📝总结

模式匹配领域就像一片未被勘探的信息大海,引领你勇敢踏入数据科学的神秘领域。这是一场独特的学习冒险,从基本概念到算法实现,逐步揭示更深层次的模式分析、匹配算法和智能模式识别的奥秘。渴望挑战模式匹配的学习路径和掌握信息领域的技术?不妨点击下方链接,一同探讨更多数据科学的奇迹吧。我们推出了引领趋势的💻 数据科学专栏:《模式之谜 | 数据奇迹解码》,旨在深度探索模式匹配技术的实际应用和创新。🌐🔍

相关文章:

【模式识别】探秘分类奥秘:最近邻算法解密与实战

​&#x1f308;个人主页&#xff1a;Sarapines Programmer&#x1f525; 系列专栏&#xff1a;《模式之谜 | 数据奇迹解码》⏰诗赋清音&#xff1a;云生高巅梦远游&#xff0c; 星光点缀碧海愁。 山川深邃情难晤&#xff0c; 剑气凌云志自修。 目录 &#x1f30c;1 初识模式识…...

【Redis】分布式锁

目录 分布式锁分布式锁实现的关键 Redisson实现分布式锁看门狗机制 分布式锁 为什么要使用分布式锁&#xff0c;或者分布式锁的使用场景&#xff1f; 定时任务。在分布式场景下&#xff0c;只控制一台服务器执行定时任务&#xff0c;这就需要分布式锁 要控制定时任务在同一时间…...

Linux访问firefox 显示Error: no DISPLAY environment variable specified

在 CentOS 7 中访问 Firefox 浏览器时&#xff0c;出现 "Error: no DISPLAY environment variable specified" 的错误提示通常是由于缺少显示环境变量导致的。 要解决这个问题&#xff0c;你可以按照以下步骤进行配置&#xff1a; 1. 确保已经安装 X Window Syst…...

线性回归简介

线性回归简介 1、情景描述2、线性回归 1、情景描述 假设&#xff0c;我们现在有这么一张图&#xff1a; 其中&#xff0c;横坐标x表示房子的面积&#xff0c;纵坐标y表示房价。我们猜想x与y之间存在线性关系&#xff1a; y k x b ykxb ykxb 现在&#xff0c;思考一个问题&…...

Log4net 教程

一、Log4net 教程 在CodeProject上找到一篇关于Log4net的教程&#xff1a;log4net Tutorial&#xff0c;这篇博客的作者是&#xff1a;Tim Corey &#xff0c;对应源代码地址为&#xff1a; https://github.com/TimCorey/Log4netTutorial&#xff0c;视频地址为&#xff1a;Ap…...

test-01-java 单元测试框架 junit 入门介绍

JUnit JUnit 是一个用于编写可重复测试的简单框架。 它是 xUnit 架构的一种实例&#xff0c;专门用于单元测试框架。 What to test? NeedDescRight结果是否正确B边界条件是否满足I能反向关联吗C有其他手段交叉检查吗E是否可以强制异常发生P性能问题 maven 入门例子 maven …...

Linux系统中跟TCP相关的系统配置项

TCP连接保活 参考 《Nginx(三) 配置文件详解 - 基础模块》3.18章节 net.ipv4.tcp_keepalive_intvl&#xff1a;设置TCP两次相邻探活检测的间隔时间。默认75秒&#xff0c;单位是秒&#xff0c;对应配置文件/proc/sys/net/ipv4/tcp_keepalive_intvl&#xff1b;net.ipv4.tcp_kee…...

python图片批量下载多线程+超时重试

背景 上篇python入门实战:爬取图片到本地介绍过如何将图片下载到本地,但是实际处理过程中会遇到性能问题:分页数过多下载时间过程、部分页面连接超时无法访问下载失败。本文从实战的角度解释一下如何处理这两个问题。 下载时间过长问题,处理方式是使用多线程,首先回顾…...

冒泡排序之C++实现

描述 冒泡排序算法是一种简单的排序算法&#xff0c;它通过将相邻的元素进行比较并交换位置来实现排序。冒泡排序的基本思想是&#xff0c;每一轮将未排序部分的最大元素逐个向右移动到已排序部分的最右边&#xff0c;直到所有元素都按照从小到大的顺序排列。 冒泡排序的算法…...

【Spring实战】04 Lombok集成及常用注解

文章目录 0. 集成1. Data2. Getter 和 Setter3. NoArgsConstructor&#xff0c;AllArgsConstructor和RequiredArgsConstructor4. ToString5. EqualsAndHashCode6. NonNull7. Builder总结 Lombok 是一款 Java 开发的工具&#xff0c;它通过注解的方式简化了 Java 代码的编写&…...

ubuntu-22.04.3 配置

1.防火墙 a、查看防火墙状态&#xff1a;inactive是关闭&#xff0c;active是开启。 sudo ufw statusb、开启防火墙。 sudo ufw enablec、关闭防火墙。 sudo ufw disable2.设置Ip ifconfigsudo cp /etc/netplan/00-installer-config.yaml /etc/netplan/00-installer-config.y…...

[工具]java_sublime的快速使用

目录 使用 : 怎么运行: 调整字体: 使用 : 新建--->写好代码后-->另存为尾缀是.java的文件 怎么运行: 在你另存为的目录下cmd调用控制台输入dos指令--->执行javac 文件名.java(有.java尾缀)(编译为.class文件)--->java 文件名(没有.class尾缀设计者认为执行的是…...

【银行测试】银行金融测试+金融项目测试点汇总...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、银行金融测试是…...

将PPT的图保持高分辨率导入到Word / WPS中

1、将PPT中画好的图组合在一起&#xff0c;选择组合后的图复制&#xff08;Ctrlc&#xff09; 2、在Word中&#xff0c;选中左上角的粘贴选项--->选择性粘贴 WPS选择元文件 / Word选择增强型图元文件 这样放大也不模糊了...

如何在Spring Boot中优雅地进行参数校验

1. 前言 在平时的开发工作中&#xff0c;我们通常需要对接口进行参数格式验证。当参数个数较少&#xff08;个数小于3&#xff09;时&#xff0c;可以使用if ... else ...手动进行参数验证。当参数个数大于3个时&#xff0c;使用if ... else ...进行参数验证就会让代码显得臃肿…...

图还能有数据库?一文带你了解图数据库是个什么东西!

图数据库 基础 简介 %% 图数据库是图数据库管理系统的简称&#xff0c;是近年来新兴的一种NoSQL数据库使用图形化的模型进行查询的数据库&#xff0c;通过节点、边和属性等方式来表示和存储数据&#xff0c;支持增删改查::CRUD::等操作。图数据库一般用于OLTP系统中&#xf…...

力扣思维题——寻找重复数

题目链接&#xff1a;https://leetcode.cn/problems/find-the-duplicate-number/description/?envTypestudy-plan-v2&envIdtop-100-liked 这题的思维难度较大。一种是利用双指针法进行计算环的起点&#xff0c;这种方法在面试里很难说清楚&#xff0c;也很难想到。大致做…...

基于Kubernetes的jenkins上线

1、基于helm 部署jenkins 要求&#xff1a;当前集群配置了storageClass&#xff0c;并已指定默认的storageClass&#xff0c;一般情况下&#xff0c;创建的storageClass即为默认类 指定默认storageClass的方式 # 如果是新创建默认类&#xff1a; apiVersion: storage.k8s.io/v1…...

每日一题——轮转数组

1. 题目描述 给定一个整数数组nums&#xff0c;将数组中的元素向右轮转k个位置&#xff0c;其中k是非负数。 示例1: 输入&#xff1a;nums [1,2,3,4,5,6,7]&#xff0c;k 3 输出&#xff1a;[5,6,7,1,2,3,4] 解释&#xff1a; 向右轮转 1步&#xff1a;[7,1,2,3,4,5,6] 向右…...

Unity手机移动设备重力感应

Unity手机移动设备重力感应 一、引入二、介绍三、测试成果X Y轴Z轴横屏的手机&#xff0c;如下图竖屏的手机&#xff0c;如下图 一、引入 大家对重力感应应该都不陌生&#xff0c;之前玩过的王者荣耀的资源更新界面就是使用了重力感应的概念&#xff0c;根据手机的晃动来给实体…...

nodejs微信小程序+python+PHP基于推荐算法的电影推荐系统-计算机毕业设计推荐django

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…...

Linux 配置 swap 区

Linux 配置 swap 区 很多时候我们需要配置 swap 主要的原因是物理内存太贵了&#xff0c; 服务器也是一样&#xff0c; 当内存不够用时&#xff0c; 系统会卡死&#xff0c; 因此我们宁愿牺牲一点性能也要让系统正常运行。 当然&#xff0c; 在系统物理内存足够的条件下&#x…...

AG16KDDF256 User Manual

AGM AG16KDDF256 是由 AGM FPGA AG16K 与 DDR-SDRAM 叠封集成的芯片&#xff0c;具有 AG16K FPGA的可编程功能&#xff0c;提供更多可编程 IO&#xff0c;同时内部连接大容量 DDR-SDRAM。  FPGA 外部管脚 FBGA256 封装&#xff0c;管脚说明请见下表 Table-1&#xff1a; Tab…...

w15初识php基础

一、计算100之内的偶数之和 实现思路 所有的偶数除2都为0 代码实现 <?php # 记录100以内的偶数和 $number1; $num0; while($number<100){if($number%20){ $num$number;}$number1; } echo $num; ?>输出的结果 二、计算100之内的奇数之和 实现思路 所有的奇数除…...

powerbuilder Primary! Delete! Filter! 三个缓冲区的作用

Primary! 主缓存区&#xff0c;放正在使用的数据。 Delete! 删除缓存区&#xff0c;放将要删除但还没有提交到数据库的数据。 Filter! 筛选缓存区&#xff0c;放不符合筛选条件的数据。 最后在update的时候根据你的update设置生成相应的SQL语句。行的状态和所在的缓存区决定生…...

Confluent 与阿里云将携手拓展亚太市场,提供消息流平台服务

10 月 31 日&#xff0c;杭州云栖大会上&#xff0c;阿里云云原生应用平台负责人丁宇宣布&#xff0c;Confluent 成为阿里云技术合作伙伴&#xff0c;合作全新升级&#xff0c;一起拓展和服务亚太市场。 本次合作伙伴签约&#xff0c;阿里云与消息流开创领导者 Confluent 将进一…...

【一起学Rust | 框架篇 | Tauri2.0框架】Tauri2.0环境搭建与项目创建

文章目录 前言一、搭建 Tauri 2.0 开发环境二、创建 Tauri 2.0 项目1.创建项目2.安装依赖4. 编译运行 三、设置开发环境四、项目结构 前言 Tauri在Rust圈内成名已久&#xff0c;凭借Rust的可靠性&#xff0c;使用系统原生的Webview构建更小的App 以及开发人员可以灵活的使用各…...

算法基础之01背包问题

01背包问题 核心思想&#xff1a; 二维数组普通写法: #include<iostream>#include<cstring>#include<algorithm>using namespace std;const int N 1010;int f[N][N]; //存 i个物品 容量不超过j 的总价值int v[N],w[N];int n,m;int main(){cin>>n>…...

Git的总体认知与具体实现

GIt概念 是一种分布式控制管理器 tips:敏捷开发 -> 先上线&#xff0c;后续开发再继续开发 集中式和分布式 集中式的版本控制系统每次在写代码时都需要从服务器中拉取一份下来&#xff0c;并且如果服务器丢失了&#xff0c;那么所有的就都丢失了&#xff0c;你本机客户端仅…...

Hadoop入门学习笔记——三、使用HDFS文件系统

视频课程地址&#xff1a;https://www.bilibili.com/video/BV1WY4y197g7 课程资料链接&#xff1a;https://pan.baidu.com/s/15KpnWeKpvExpKmOC8xjmtQ?pwd5ay8 Hadoop入门学习笔记&#xff08;汇总&#xff09; 目录 三、使用HDFS文件系统3.1. 使用命令操作HDFS文件系统3.1.…...

JavaWeb—html, css, javascript, dom,xml, tomcatservlet

文章目录 快捷键HTML**常用特殊字符替代:****标题****超链接标签****无序列表、有序列表****无序列表**:ul/li 基本语法**有序列表ol/li:****图像标签(img)**** 表格(table)标签****表格标签-跨行跨列表格****form(表单)标签介绍****表单form提交注意事项**div 标签p 标签sp…...

LangChain 31 模块复用Prompt templates 提示词模板

LangChain系列文章 LangChain 实现给动物取名字&#xff0c;LangChain 2模块化prompt template并用streamlit生成网站 实现给动物取名字LangChain 3使用Agent访问Wikipedia和llm-math计算狗的平均年龄LangChain 4用向量数据库Faiss存储&#xff0c;读取YouTube的视频文本搜索I…...

深入理解 Git 分支管理:提升团队协作与开发效率

目录 前言1 什么是分支2 分支的好处2.1 并行开发的支持2.2 独立性与隔离性2.3 灵活的版本控制2.4 提高安全性和代码质量2.5 项目历史的清晰记录 3 Git 分支操作命令3.1 git branch -v3.2 git branch 分支名称3.3 git checkout 分支名称3.4 git merge 分支名称3.5 git rebase 分…...

WPF StackPanel

StackPanel是一个控件容器&#xff0c;它按照一个方向&#xff08;水平或垂直&#xff09;堆叠子元素&#xff0c;使得它们沿一个轴线对齐。你可以在StackPanel中放置其他控件&#xff0c;如按钮、标签、文本框、图片等等。这些控件的排列方式由StackPanel按照指定的方向自动确…...

由正规表达式构造DFA,以及DFA的相关化简

目录 1.由正规式到DFA 首先讲如何从正规式到NFA 如何从NFA到DFA 2.DFA的化简 3.DFA和NFA的区别 1.由正规式到DFA 正规式--->NFA---->DFA 首先讲如何从正规式到NFA 转换规则: 例题1&#xff1a;这里圆圈里面的命名是随意的&#xff0c;只要能区别开就可以了 如何…...

模式识别与机器学习(九):Adaboost

1.原理 AdaBoost是Adaptive Boosting&#xff08;自适应增强&#xff09;的缩写&#xff0c;它的自适应在于&#xff1a;被前一个基本分类器误分类的样本的权值会增大&#xff0c;而正确分类的样本的权值会减小&#xff0c;并再次用来训练下一个基本分类器。同时&#xff0c;在…...

【JAVA】分布式链路追踪技术概论

目录 1.概述 2.基于日志的实现 2.1.实现思想 2.2.sleuth 2.2.可视化 3.基于agent的实现 4.联系作者 1.概述 当采用分布式架构后&#xff0c;一次请求会在多个服务之间流转&#xff0c;组成单次调用链的服务往往都分散在不同的服务器上。这就会带来一个问题&#xff1a;…...

ZooKeeper 使用介绍和原理详解

目录 1. 介绍 重要性 应用场景 2. ZooKeeper 架构 服务角色 数据模型 工作原理 3. 安装和配置 下载 ZooKeeper 安装和配置 启动 ZooKeeper 验证和管理 停止和关闭 4. ZooKeeper 数据模型 数据结构和层次命名空间&#xff1a; 节点类型和 Watcher 机制&#xff…...

模式识别与机器学习(八):决策树

1.原理 决策树&#xff08;Decision Tree&#xff09;&#xff0c;它是一种以树形数据结构来展示决策规则和分类结果的模型&#xff0c;作为一种归纳学习算法&#xff0c;其重点是将看似无序、杂乱的已知数据&#xff0c;通过某种技术手段将它们转化成可以预测未知数据的树状模…...

Pinely Round 3 (Div. 1 + Div. 2)(A~D)(有意思的题)

A - Distinct Buttons 题意&#xff1a; 思路&#xff1a;模拟从&#xff08;0,0&#xff09;到每个位置需要哪些操作&#xff0c;如果总共需要4种操作就输出NO。 // Problem: A. Distinct Buttons // Contest: Codeforces - Pinely Round 3 (Div. 1 Div. 2) // URL: https…...

在Linux下探索MinIO存储服务如何远程上传文件

&#x1f308;个人主页&#xff1a;聆风吟 &#x1f525;系列专栏&#xff1a;网络奇遇记、Cpolar杂谈 &#x1f516;少年有梦不应止于心动&#xff0c;更要付诸行动。 文章目录 &#x1f4cb;前言一. 创建Buckets和Access Keys二. Linux 安装Cpolar三. 创建连接MinIO服务公网地…...

持续集成交付CICD:Linux 部署 Jira 9.12.1

目录 一、实验 1.环境 2.K8S master节点部署Jira 3.Jira 初始化设置 4.Jira 使用 一、实验 1.环境 &#xff08;1&#xff09;主机 表1 主机 主机架构版本IP备注master1K8S master节点1.20.6192.168.204.180 jenkins slave &#xff08;从节点&#xff09; jira9.12.1…...

Linux命令-查看内存、GC情况及jmap 用法

查看进程占用内存、CPU使用情况 1、查看进程 #jps 查看所有java进程 #top 查看cpu占用高进程 输入m &#xff1a;根据内存排序 topMem: 16333644k total, 9472968k used, 6860676k free, 165616k buffers Swap: 0k total, 0k used, 0k free, 6…...

nginx安装letsencrypt证书

1.安装推荐安装letsencrypt证书的客户端工具 官方推荐通过cerbot客户端安装letsencrypt 官方推荐使用snap客户端安装cerbot客户端 apt install snapd snap install --classic certbot 建立certbot软链接&#xff1a;ln -s /snap/bin/certbot /usr/bin/certbot 2.开始安装letse…...

docker笔记1-安装与基础命令

docker的用途&#xff1a; 可以把应用程序代码及运行依赖环境打包成镜像&#xff0c;作为交付介质&#xff0c;在各种环境部署。可以将镜像&#xff08;image&#xff09;启动成容器&#xff08;container&#xff09;&#xff0c;并提供多容器的生命周期进行管理&#xff08;…...

VSCode软件与SCL编程

原创 NingChao NCLib 博途工控人平时在哪里技术交流博途工控人社群 VSCode简称VSC&#xff0c;是Visual studio code的缩写&#xff0c;是由微软开发的跨平台的轻量级编辑器&#xff0c;支持几乎所有主流的开发语言的语法高亮、代码智能补全、插件扩展、代码对比等&#xff0c…...

Opencv中的滤波器

一副图像通过滤波器得到另一张图像&#xff0c;其中滤波器又称为卷积核&#xff0c;滤波的过程称之为卷积。 这就是一个卷积的过程&#xff0c;通过一个卷积核得到另一张图片&#xff0c;明显发现新的到的图片边缘部分更加清晰了&#xff08;锐化&#xff09;。 上图就是一个卷…...

<JavaEE> 基于 TCP 的 Socket 通信模型

目录 一、认识相关API 1&#xff09;ServerSocket 2&#xff09;Socket 二、TCP字节流套接字通信模型概述 三、回显客户端-服务器 1&#xff09;服务器代码 2&#xff09;客户端代码 一、认识相关API 1&#xff09;ServerSocket ServerSocket 常用构造方法ServerSocke…...

[THUPC 2024 初赛] 二进制 (树状数组单点删除+单点查询)(双堆模拟set)

题解 题目本身不难想 首先注意到所有查询的序列长度都是小于logn级别的 我们可以枚举序列长度len&#xff0c;然后用类似滑动窗口的方法&#xff0c;一次性预处理出每种字串的所有出现位置&#xff0c;也就是开N个set去维护所有的位置。预处理会进行O(logn)轮&#xff0c;每…...

机器学习算法(11)——集成技术(Boosting——梯度提升)

一、说明 在在这篇文章中&#xff0c;我们学习了另一种称为梯度增强的集成技术。这是我在机器学习算法集成技术文章系列中与bagging一起介绍的一种增强技术。我还讨论了随机森林和 AdaBoost 算法。但在这里我们讨论的是梯度提升&#xff0c;在我们深入研究梯度提升之前&#xf…...