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

【机器学习】手撕封装PCA——将高维数据映射到低维数据的过程

PCA将高维数据映射到低维数据的过程

  • 一、摘要
  • 二、PCA的降维思路
  • 三、PCA代码实现降维过程
    • 3.1 PCA类的实现与封装
    • 3.2 PCA类的使用示例
  • 四、PCA的恢复过程

一、摘要

本文详细介绍了主成分分析法(PCA)在高维数据降维中的应用。首先,阐述了PCA的基本原理,即通过寻找前k个主成分对应的轴的方向,实现从高维数据向低维数据的映射。随后,讲解了如何通过PCA将样本数据从N维映射到k维,包括主成分的计算矩阵乘法降维过程的具体实现。此外,还涉及了PCA的编程实现,包括如何封装PCA为一个类,以及如何通过该类进行数据的降维和恢复。最后,通过实际编程实验展示了PCA降维的基本原理和应用效果,强调了PCA在数据降维中的重要作用。

二、PCA的降维思路

  1. 主成分分析法用于将高维数据映射到低维数据,涉及求取数据集的前n个主成分。

  2. 主成分代表高维空间中的坐标轴方向,通过这些方向可以将数据集从高维空间转换到低维空间。

  3. 样本数据的表示与主成分矩阵

    • 样本数据X表示为m行n列的矩阵,其中m是样本数量,n是特征数量。
      高维数据矩阵 X : X = ( X 1 ( 1 ) X 2 ( 1 ) … X n ( 1 ) X 1 ( 2 ) X 2 ( 2 ) … X n ( 2 ) ⋮ ⋮ ⋱ ⋮ X 1 ( m ) X 2 ( m ) … X n ( m ) ) 高维数据矩阵X:X = \begin{pmatrix} X_1^{(1)} & X_2^{(1)} & \dots & X_n^{(1)} \\ X_1^{(2)} & X_2^{(2)} & \dots & X_n^{(2)} \\ \vdots & \vdots & \ddots & \vdots \\ X_1^{(m)} & X_2^{(m)} & \dots & X_n^{(m)} \end{pmatrix} 高维数据矩阵XX= X1(1)X1(2)X1(m)X2(1)X2(2)X2(m)Xn(1)Xn(2)Xn(m)
      表示 ( m ) 个样本,每个样本有 ( n ) 个特征,维度为 ( m x n )。
      维度为 (m x n)
    • 通过主成分分析法求出的前k个主成分表示为w矩阵,w是一个k行n列的矩阵,代表k个单位方向向量。
      映射矩阵 W k : W k = ( W 1 ( 1 ) W 2 ( 1 ) … W n ( 1 ) W 1 ( 2 ) W 2 ( 2 ) … W n ( 2 ) ⋮ ⋮ ⋱ ⋮ W 1 ( k ) W 2 ( k ) … W n ( k ) ) 映射矩阵W_k:W_k = \begin{pmatrix} W_1^{(1)} & W_2^{(1)} & \dots & W_n^{(1)} \\ W_1^{(2)} & W_2^{(2)} & \dots & W_n^{(2)} \\ \vdots & \vdots & \ddots & \vdots \\ W_1^{(k)} & W_2^{(k)} & \dots & W_n^{(k)} \end{pmatrix} 映射矩阵WkWk= W1(1)W1(2)W1(k)W2(1)W2(2)W2(k)Wn(1)Wn(2)Wn(k)
      维度为 (n x k)
  4. 样本数据的降维映射:矩阵乘法实现降维

    • 公式
      X ⋅ W k T = X k X \cdot W_k^T = X_k XWkT=Xk
    • 维度标注
      • ( X ) 的维度为 ( m x n )
      • (Wk) 的维度为 ( n x k )
      • 运算结果 ( Xk ) 的维度为 ( m x k )
    1. 公式含义
      表示高维数据矩阵 ( X ) 与映射矩阵 ( Wk ) 的转置(( W_k^T ))进行矩阵乘法运算,最终得到低维数据矩阵 ( Xk )。这一过程是高维数据向低维映射的核心计算步骤。换言之,矩阵乘法实现样本数据从N维到k维的映射,通过将x与w的转置相乘完成。x是一个m行n列的矩阵,w是一个k行n列的矩阵,转置后变为n行k列的矩阵。乘法结果得到一个m行k列的矩阵,即降维后的样本数据。

    2. 维度分析

      • ( X ) 是 ( m x n ) 矩阵,代表 ( m ) 个样本,每个样本有 ( n ) 个特征(原始高维数据)。
      • ( Wk ) 是 ( n x k ) 矩阵(( k < n )),用于定义低维空间的映射规则。其转置 Wk维度为 ( k x n )。
      • 根据矩阵乘法规则(前一矩阵的列数与后一矩阵的行数需匹配), X ⋅ W k T X \cdot W_k^T XWkT运算后得到 ( m x k ) 的 ( Xk ),实现了从 ( n ) 维到 ( k ) 维的降维,( Xk ) 即为降维后的低维数据,在保留原始数据主要特征的同时降低了维度。

三、PCA代码实现降维过程

3.1 PCA类的实现与封装

  1. 在PyCharm中新建pythonProject工程并在该工程中加入了pca.py文件,封装了PCA类。

  2. PCA类构造函数传入n_components参数,表示要多少个主成分。

  3. 构造函数中初始化n_components和components变量,components用于存储主成分方向向量。

  4. 具体代码:

    import numpy as npclass PCA:def __init__(self,n_components):"""初始化PCA"""assert n_components >= 1, "n_components must be valid."self.n_components = n_componentsself.components = Nonedef fit(self,X,eta=0.01,n_iters=1e4):"""获得数据集X的前n个主成分"""assert self.n_components <= X.shape[1],\"n_components must not be greater than the feature number of X."def demean(X):"""均值归零"""return X - np.mean(X,axis=0)def f(w,X):"""目标函数:求w向量,使得目标函数在该方向上的方差最大"""return np.sum(X.dot(w) ** 2)/len(X)def df(w,X):"""求梯度"""return X.T.dot(X.dot(w)) * 2. / len(X)def direction(w):"""单位方向向量函数"""return w / np.linalg.norm(w)def first_component(X,initial_w,eta=0.01,n_iters=1e4,epsilon=1e-8):"""求第一个主成分"""w = direction(initial_w)cur_iter = 0while cur_iter < n_iters:gradient = df(w,X)last_w = ww = w + eta * gradient   # 梯度上升法w = direction(w)if (abs(f(w,X) - f(last_w,X))) < epsilon:breakcur_iter += 1return w# 均值归零,将高维矩阵X进行均值归零处理X_pca = demean(X)# 定义一个空的低维矩阵Wk,也就是映射矩阵,self.components_ = np.empty(shape=(self.n_components,X.shape[1]))for i in range(self.n_components):initial_w = np.random.random(X_pca.shape[1])w = first_component(X_pca,initial_w,eta,n_iters)self.components_[i,:] = wX_pca = X_pca - X_pca.dot(w).reshape(-1,1) * wreturn selfdef transform(self,X):"""将给定的X,映射到各个主成分分量中"""assert X.shape[1] == self.components_.shape[1]# 通过矩阵相乘,实现降维:m x n * n x k == m x k 矩阵return  X.dot(self.components_.T)def inverse_transform(self,X):"""将给定的X,反向映射回元原来的特征空间"""assert X.shape[1] == self.components_.shape[0]# 通过矩阵相乘,实现维数还原:m x k * k x n == m x n 矩阵return X.dot(self.components_)def __repr__(self):return "PCA(n_components=%d)" % self.n_components
    

    在这里插入图片描述

    • 设置fit和transform方法,fit方法用于计算主成分,transform方法用于降维处理。
    • fit方法传入样本数据x和梯度上升法的相关参数,计算前n_components个主成分。
    • transform方法传入样本数据x和已计算出的主成分矩阵,将数据降维到k维。
    • inverse_transform方法用于将低维数据恢复成高维数据。

3.2 PCA类的使用示例

  1. 在notebook中使用封装的PCA类,加载虚拟数据集并进行降维处理。
  2. 实例化PCA类并传入n_components参数,调用fit方法计算主成分。
  3. 调用transform方法将数据降维到k维,调用inverse_transform方法将低维数据恢复成高维数据。
  4. 通过绘制降维前后的数据点,展示PCA降维的效果。
  5. 演示过程:
    • 导入工程
      # 导入在PyCharm中封装好的工程项目
      import sys
      project_path = 'D:/PycharmProjects/pythonProject/'
      if project_path not in sys.path:sys.path.append(project_path)
      
    • 具体实现
      from PCA import PCA
      import numpy as np
      import matplotlib.pyplot as pltX = np.empty((100, 2))
      X[:, 0] = np.random.uniform(0., 100., size=100)
      X[:, 1] = 0.75 * X[:, 0] + 3. + np.random.normal(0, 10., size=100)# 初始化PCA,传入主成分数量为2个
      pca = PCA(n_components=2)# 获取X数据集的前2个主成分
      pca.fit(X)# 查看由2个主成分所构成的矩阵
      pca.components_# 调用fit_transform函数进行降维操作
      X_reduction = pca.transform(X)# 查看X_reduction维度
      X_reduction.shape# 如果期望将数据降到更低维度,比如降到 1 维
      # 那么在初始化 PCA 类时,将 n_components 设置为 1 即可,即 pca = PCA(n_components=1) ,这样再调用 transform 方法后得到的结果维度就会是 (100, 1) 。
      pca = PCA(n_components=1)
      pca.fit(X)
      # 调用fit_transform函数进行降维操作
      X_reduction = pca.transform(X)# 查看X_reduction维度
      X_reduction.shape
      # PCA恢复
      X_restore = pca.inverse_transform(X_reduction)
      # 查看
      X_restore.shape
      # 绘制图像
      plt.scatter(X[:,0], X[:,1], color='b', alpha=0.5)
      plt.scatter(X_restore[:,0], X_restore[:,1], color='r', alpha=0.5)
      plt.show()
      
      执行过程:
      在这里插入图片描述
      在这里插入图片描述
      在这里插入图片描述

四、PCA的恢复过程

  1. 通过将降维后的数据与w矩阵相乘,可以恢复成原始的高维数据。
  2. 恢复过程中会丢失一些信息,但可以从数学上实现低维到高维的映射。
  • 矩阵定义

    • 低维数据矩阵
      X k = ( X 1 ( 1 ) X 2 ( 1 ) … X k ( 1 ) X 1 ( 2 ) X 2 ( 2 ) … X k ( 2 ) … … … … X 1 ( m ) X 2 ( m ) … X k ( m ) ) X_k = \begin{pmatrix} X_1^{(1)} & X_2^{(1)} & \dots & X_k^{(1)} \\ X_1^{(2)} & X_2^{(2)} & \dots & X_k^{(2)} \\ \dots & \dots & \dots & \dots \\ X_1^{(m)} & X_2^{(m)} & \dots & X_k^{(m)} \end{pmatrix} Xk= X1(1)X1(2)X1(m)X2(1)X2(2)X2(m)Xk(1)Xk(2)Xk(m) 维度为 ( m x k )。
    • 映射矩阵 W k = ( W 1 ( 1 ) W 2 ( 1 ) … W n ( 1 ) W 1 ( 2 ) W 2 ( 2 ) … W n ( 2 ) … … … … W 1 ( k ) X 2 ( k ) … X n ( k ) ) W_k = \begin{pmatrix} W_1^{(1)} & W_2^{(1)} & \dots & W_n^{(1)} \\ W_1^{(2)} & W_2^{(2)} & \dots & W_n^{(2)} \\ \dots & \dots & \dots & \dots \\ W_1^{(k)} & X_2^{(k)} & \dots & X_n^{(k)} \end{pmatrix} Wk= W1(1)W1(2)W1(k)W2(1)W2(2)X2(k)Wn(1)Wn(2)Xn(k) 维度为 ( k x n )。
  • 公式 X k ⋅ W k = X m X_k \cdot W_k = X_m XkWk=Xm 维度标注为 m x k、k x n、m x n 。

  • 数据映射逻辑

    • X k X_k Xk 是低维数据矩阵,包含 ( m ) 个样本,每个样本有 ( k ) 个特征,代表高维数据降维后的结果。
    • W k W_k Wk是映射矩阵,用于定义低维空间到高维空间的转换规则。通过矩阵乘法 ( X_k \cdot W_k ),理论上可将低维数据 ( X_k ) 恢复或映射回高维空间,得到 ( m \times n ) 的高维数据 ( X_m )。
  • 矩阵运算意义

    • 从维度看,( X_k )(( m x k ))与 Wk 满足矩阵乘法规则(前一矩阵的列数与后一矩阵的行数均为 ( k )),运算结果 ( Xm ) 的维度为 ( m x n ),即还原出包含 ( n ) 个特征的高维数据。这一过程体现了“低维数据通过映射矩阵重建高维数据”的逆向映射关系,常见于数据降维后的恢复或特征重构场景。

相关文章:

【机器学习】手撕封装PCA——将高维数据映射到低维数据的过程

PCA将高维数据映射到低维数据的过程 一、摘要二、PCA的降维思路三、PCA代码实现降维过程3.1 PCA类的实现与封装3.2 PCA类的使用示例 四、PCA的恢复过程 一、摘要 本文详细介绍了主成分分析法&#xff08;PCA&#xff09;在高维数据降维中的应用。首先&#xff0c;阐述了PCA的基…...

LangChain开发(七)自定义输出格式(JSON/XML/YAML)

文章目录 JSON结构输出未使用PydanticPydantic流式处理 XML结构输出xml输出指定字段 YAML输出源码地址参考资料 JSON结构输出 虽然一些模型提供商支持内置的方法返回结构化输出&#xff0c;但并非所有都支持。我们可以使用输出解析器来帮助用户通过指示指定任意的JSON模型&…...

RustDesk部署到linux(自建服务器)

简介 ‌RustDesk‌是一款开源的远程桌面软件&#xff0c;由中国开发者开发&#xff0c;使用Rust编程语言构建。它支持跨平台运行&#xff0c;可以在Windows、macOS、Linux、iOS、Android和Web等多个平台上使用。RustDesk的主要功能包括远程桌面访问、文件传输、文本聊天等&…...

分布式锁,redisson,redis

目录 什么是分布式锁分布式锁解决什么问题分布式锁的特点使用分布式锁的场景怎么使用分布式锁1. 添加依赖2. 配置 Redisson 客户端3. 使用 Redisson 实现分布式锁 什么是分布式锁 分布式锁是一种锁机制&#xff0c;用于在分布式环境下&#xff0c;解决多个线程并发访问同一共享…...

linux常用指令(9)

加油同志们,我们离胜利不远了,再有两天我们就可以了解完linux的一些基本常用指令了,到时我们便可以进入一些shell脚本语法了,那么话不多说,来看. 1.more指令 功能描述&#xff1a;more指令是一个基于vi编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容. 基本语法…...

深入解析 JVM 内存区域及核心概念

深入解析 JVM 内存区域及核心概念 Java 虚拟机&#xff08;JVM&#xff09;内部划分了多个内存区域&#xff0c;每个区域存储不同类型的数据并承担不同的职责。本文将详细介绍以下内容&#xff1a; 程序计数器&#xff1a;记录当前线程正在执行的字节码指令及其“行号”信息&a…...

字节跳动春招研发部笔试题解

字节跳动春招研发部笔试题 1.万万没想到之聪明的编辑 我叫王大锤&#xff0c;是一家出版社的编辑。我负责校对投稿来的英文稿件&#xff0c;这份工作非常烦人&#xff0c;因为每天都要去修正无数的拼写错误。但是&#xff0c;优秀的人总能在平凡的工作中发现真理。我发现一个发…...

java对象模型

java对象自身的存储模型JVM会给这个类创建一个instanceKlass&#xff0c;保存在方法区&#xff0c;用来在JVM层表示该Java类。 a类。当我们在Java代码中&#xff0c;使用new创建一个对象的时候&#xff0c;JVM会在栈中给对象赋值&#xff0c;会在堆中创建一个instanceOopDesc对…...

深入理解指针(3)(C语言版)

文章目录 前言 一、字符指针变量二、数组指针变量2.1 数组指针变量是什么2.2 数组指针变量怎么初始化2.2.1 静态初始化2.2.2 动态初始化 三、二维数组传参的本质四、函数指针变量4.1 函数指针变量的创建4.2 函数指针变量的使用4.3 typedef关键字4.4拓展 五、函数指针数组六、转…...

Linux内核 内存管理 物理内存初始化流程

1.‌ARM64页表初始化流程图 start_kernel()│▼ setup_arch() // 架构相关初始化│▼ early_fixmap_init() // 初始化Fixmap&#xff08;临时映射设备树等&#xff09;│▼ arm64_memblock_init() // 从设备树解析内存布局│▼ arm…...

Day23:和为s的数字

购物车内的商品价格按照升序记录于数组 price。请在购物车中找到两个商品的价格总和刚好是 target。若存在多种情况&#xff0c;返回任一结果即可。 示例 1&#xff1a; 输入&#xff1a;price [3, 9, 12, 15], target 18 输出&#xff1a;[3,15] 或者 [15,3]示例 2&#x…...

Transformer 通关秘籍2:利用 BERT 将文本 token 化

前面两节分别通过两个代码示例展示了模型将文本转换为 token 之后是什么样的&#xff0c;希望你可以对此有一个感性的认识。 本节来简要介绍一下将一个连续的文本转换为 token 序列的大致过程&#xff0c;这个过程被称为分词&#xff0c;也叫 tokenization。 在你没了解这方面…...

电脑干货:万能驱动--EasyDrv8

目录 万能驱动EasyDrv8 功能介绍 主程序界面 驱动解压与安装 PE环境支持 系统部署环境 桌面环境一键解决方案 万能驱动8电脑版是由IT天空出品的一款智能识别电脑硬件并自动安装驱动的工具&#xff0c;一般又称为it天空万能驱动&#xff0c;万能驱动vip版&#xff0c;简称…...

18502 字符串哈希匹配字符串

18502 字符串哈希匹配字符串 ⭐️难度&#xff1a;中等 &#x1f31f;考点&#xff1a;字符串hash &#x1f4d6; &#x1f4da; import java.util.Arrays; import java.util.LinkedList; import java.util.Queue; import java.util.Scanner;public class Main {static int…...

openmmlab介绍 一下

OpenMMLab 是由商汤科技&#xff08;SenseTime&#xff09;发起并维护的开源深度学习项目&#xff0c;专注于计算机视觉领域。它提供了一系列模块化、可扩展的工具库&#xff0c;旨在帮助研究者和开发者高效地实现、复现和部署前沿的视觉算法。OpenMMLab 的设计强调‌模块化‌、…...

基于javaweb的SpringBoot线上网络文件管理系统设计与实现(源码+文档+部署讲解)

技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论…...

【设计模式】工厂模式详解-----简单工厂模式、工厂方法模式、抽象工厂模式

工厂模式详解 一、概述 工厂模式&#xff08;Factory Pattern&#xff09; 是一种 创建型设计模式&#xff0c;用于 封装对象的创建逻辑&#xff0c;避免在代码中直接实例化对象&#xff0c;从而提高代码的 可维护性、扩展性和解耦性。 二、工厂模式分类 工厂模式包括 简单工…...

【雅思播客09】Turn Left here.

Hello everyone! And welcome to my channel! Im Reevs. Good morning! 大家好&#xff0c;欢迎来到懒人英语晨读栏目&#xff0c;我是Reevs&#xff0c;早上好呀。 I have a great lesson for you today. 今天我有一堂非常棒的课。 We have an elementary lesson, which is …...

初阶7 vector

本章重点 vector的介绍vector的使用vector的模拟实现 1.vector的介绍 vector就类似数据结构中的顺序表 vector是表示可变大小数组的序列容器。 就像数组一样&#xff0c;vector也采用的连续存储空间来存储元素。 意味着可以采用下标对vector的元素 进行访问&#xff0c;和数…...

归并排序总结

归并排序是分治法的典型应用&#xff0c;把两个或k个有序的子序列合并为一个。2路归并&#xff0c;2合一。k路归并&#xff0c;k合一。内部排序通常采用2路归并排序&#xff0c;先将数组分成两半&#xff0c;分别排序&#xff0c;然后合并。合并的过程需要将两个有序的子数组合…...

ollama迁移已下载的单个模型到服务器

ollama迁移已下载的单个模型到服务器 场景 ollama是面向用户级的&#xff0c;部署和运行都很简单&#xff0c;是否高效就另说了。但最起码&#xff0c;他能充分利用用户的硬件设备&#xff0c;在GPU不足也能调用cpu和内存去加持。 ollama运行的模型基本是量化版本的&#xf…...

基于SSM+Vue物流信息管理系统(附源码)

预览页面 获取方式 https://gitee.com/XiaoLin_Java/communion/blob/master/README.en.md...

docker创建registry镜像仓库2.8版本

目录 shell脚本内容 运行效果 问题与解决 涉及镜像包registry:2.8&#xff08;x86版本&#xff09; shell脚本内容 [roottest1 docker]# cat registry.sh #!/bin/bash read -p "请输入用户:" user read -p "请输入密码:" passpathpwd passdir"$…...

Ubuntu下用QEMU模拟运行OpenBMC

1、前言 在调试过程中&#xff0c;安装了很多依赖库&#xff0c;具体没有记录。关于kvm&#xff0c;也没理清具体有什么作用。本文仅记录&#xff0c;用QEMU成功的将OpenBMC跑起来的过程&#xff0c;做备忘&#xff0c;也供大家参考。 2、环境信息 VMware Workstation 15 Pro…...

Unity Shader编程】之复杂光照

在Unity Shader的LightMode标签中&#xff0c;除了前向渲染和延迟渲染外&#xff0c;还支持多种渲染模式设置。以下是主要分类及用途&#xff1a; 一、核心渲染路径模式 前向渲染相关 ForwardBase 用于基础光照计算&#xff0c;处理环境光、主平行光、逐顶点/SH光源及光照贴图。…...

从零构建大语言模型全栈开发指南:第二部分:模型架构设计与实现-2.1.3前馈网络(FFN)与激活函数(GELU)优化

👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 2.1.3 前馈网络(FFN)与激活函数(GELU)优化1. 前馈网络(FFN)的架构设计与数学原理1.1 FFN在Transformer中的核心作用2. GELU激活函数的数学特性与优化2.1 GELU的数学形式与近似计算3. 逐行代码实现…...

STM32 MODBUS-RTU主从站库移植

代码地址 STM32MODBUSRTU: stm32上的modbus工程 从站 FreeModbus是一个开源的Modbus通信协议栈实现。它允许开发者在各种平台上轻松地实现Modbus通信功能&#xff0c;包括串口和以太网。FreeMODBUS提供了用于从设备和主站通信的功能&#xff0c;支持Modbus RTU和Modbus TCP协…...

计算机是如何工作的

目录 冯诺依曼体系 CPU基本工作流程&#xff1a; 逻辑门 门电路 算术逻辑单元 ALU&#xff08;Arithmetic&LogicUnit&#xff09; 算术单元(Arithmetic Unit) 逻辑单元(Logic Unit) ALU符号 寄存器(Register)和内存(RAM) 控制单元 CU(Control Unit) 指令(Instruc…...

Arduino、ESP32驱动GUVA-S12SD UV紫外线传感器(光照传感器篇)

目录 1、传感器特性 2、控制器和传感器连线图 3、驱动程序 UV紫外线传感器是一个测试紫外线总量的最佳传感器,它不需要使用波长滤波器,只对紫外线敏感。 Arduino UV紫外线传感器,直接输出对应紫外线指数(UV INDEX)的线性电压,输出电压范围大约0~1100mV(对应UV INDEX值…...

【NLP 48、大语言模型的神秘力量 —— ICL:in context learning】

目录 一、ICL的优势 1.传统做法 2.ICL做法 二、ICL的发展 三、ICL成因的两种看法 1.meta learning 2.Bayesian Inference 四、ICL要点 ① 语言模型的规模 ② 提示词prompt中提供的examples数量和顺序 ③ 提示词prompt的形式&#xff08;format&#xff09; 五、fine-tune VS I…...

面向对象软件工程实践软件案例

智力运动-数字化思维训练课程介绍 数字化思维训练是科技赋能素质教育创新实践项目&#xff0c;通过数字化信息化手段&#xff0c;深度融合优质原创智力运动教育课程资源&#xff0c;服务幼儿园与小学&#xff0c;提供信息时代校园素质教育教学解决方案。在《面向对象软件工程》…...

PX4飞控-接收MAVLINK消息(2)-生成MAVLINK_MSG_ID_***.h文件

我在自制的底板上跑vxworks操作系统中移植了MAVLINK的C库用来与PX4飞控进行通信&#xff0c;其中使用的C库和其他依赖文件&#xff0c;例如common文件夹均为从飞控源码中获取&#xff0c;文件获取位置为px4-Autopolite/bulid/mavlink中&#xff0c;因为PX4源码中自带MAVLINK的依…...

Spring Boot 连接 MySQL 配置参数详解

Spring Boot 连接 MySQL 配置参数详解 前言参数及含义常用参数及讲解和示例useUnicode 参数说明&#xff1a; 完整配置示例注意事项 前言 在 Spring Boot 中使用 Druid 连接池配置 MySQL 数据库连接时&#xff0c;URL 中 ? 后面的参数用于指定连接的各种属性。以下是常见参数…...

【数据结构】_单链表_相关面试题(二)

本章重点 hello友友们~ 今天我们将对单链表的后半部分的相关面试题进行详细解析&#xff0c;下面就跟着我一起开启吧~ really GO&#xff01; 1.相交链表 题目&#xff1a; 输入两个链表&#xff0c;找出它们的第一个公共结点。 代码分析&#xff1a; //找到相交结点&#xf…...

深入理解指针(2)(C语言版)

文章目录 前言一、数组名的理解二、使用指针访问数组三、一维数组传参的本质四、冒泡排序五、二级指针六、指针数组七、指针数组模拟二维数组总结 前言 在上一篇文章中&#xff0c;我们初步了解了指针的基本概念和用法。今天&#xff0c;我们将继续深入探索指针在数组、函数传…...

二叉树相关算法实现:判断子树与单值二叉树

目录 一、判断一棵树是否为另一棵树的子树 &#xff08;一&#xff09;核心思路 &#xff08;二&#xff09;代码实现 &#xff08;三&#xff09;注意要点 二、判断一棵树是否为单值二叉树 &#xff08;一&#xff09;核心思路 &#xff08;二&#xff09;代码实现…...

redux ,react-redux,redux-toolkit 简单总结

Redux、React-Redux 和 Redux Toolkit 是协同工作的三个库&#xff0c;各自承担不同角色&#xff0c;相互协同。 Redux&#xff1a;基础底座 底层状态管理库&#xff0c;负责状态存储、Action 派发和 Reducer 执行 ​React-Redux&#xff1a;连接 React 组件与 Redux Store 通…...

5. 实现一个中间件

原文地址: 实现一个中间件 更多内容请关注&#xff1a;php代码框架 理解中间件 中间件&#xff08;Middleware&#xff09; 是一种在请求被路由到控制器方法之前或响应返回客户端之前执行的代码。它通常用于处理通用任务&#xff0c;如身份验证、日志记录、CORS 处理等。 在…...

数据库理论基础

数据库理论基础 1.1 什么是数据库 数据&#xff1a; 描述事物的符号记录&#xff0c; 可以是数字、 文字、图形、图像、声音、语言等&#xff0c;数据有多种形式&#xff0c;它们都可以经过数字化后存入计算机。 数据库&#xff1a; 存储数据的仓库&#xff0c;是长期存放在…...

STM32学习笔记之振荡器(原理篇)

&#x1f4e2;&#xff1a;如果你也对机器人、人工智能感兴趣&#xff0c;看来我们志同道合✨ &#x1f4e2;&#xff1a;不妨浏览一下我的博客主页【https://blog.csdn.net/weixin_51244852】 &#x1f4e2;&#xff1a;文章若有幸对你有帮助&#xff0c;可点赞 &#x1f44d;…...

SQL Server安装程序无法启动:系统兼容性检查失败

问题现象&#xff1a; 运行 SQL Server 2022 安装程序时&#xff0c;提示 “硬件或软件不满足最低要求”&#xff0c;安装向导直接退出或无法继续。 快速诊断 操作系统版本检查&#xff1a; # 查看 Windows 版本&#xff08;需 20H2 或更高&#xff09; winver 支持的系统&…...

C++20 中的std::c8rtomb和 std::mbrtoc8

文章目录 1. 引言2. std::c8rtomb 函数详解3. std::mbrtoc8 函数详解4. 使用示例5. 注意事项6. 总结 1. 引言 C20 标准引入了对 UTF-8 编码的更好支持&#xff0c;其中包括两个重要的函数&#xff1a;std::c8rtomb 和 std::mbrtoc8。这两个函数分别用于将 UTF-8 编码的字符转换…...

树形结构的工具类TreeUtil

这个地方是以null为根节点&#xff0c;相关以null或者0自己在TreeUtil中加代码&#xff0c;就行 基础类 package com.jm.common.entity;import lombok.Data;import java.util.ArrayList; import java.util.List;/*** Author:JianWu* Date: 2025/3/26 9:02*/ Data public clas…...

【零基础入门unity游戏开发——2D篇】2D物理系统 —— 2D刚体组件(Rigidbody2D)

考虑到每个人基础可能不一样,且并不是所有人都有同时做2D、3D开发的需求,所以我把 【零基础入门unity游戏开发】 分为成了C#篇、unity通用篇、unity3D篇、unity2D篇。 【C#篇】:主要讲解C#的基础语法,包括变量、数据类型、运算符、流程控制、面向对象等,适合没有编程基础的…...

人员进出新视界:视觉分析算法的力量

视觉分析赋能离岗检测新策略 随着时代的发展&#xff0c;失业率增加&#xff0c;社会安保压力也随之增大。企业为了提升管理效率&#xff0c;保障园区安全&#xff0c;对员工离岗检测的需求日益迫切。传统的离岗管理方式&#xff0c;如人工巡逻、打卡记录等&#xff0c;不仅效率…...

LabVIEW液压振动锤控制系统

在现代工程机械领域&#xff0c;液压振动锤的高效与精准控制日益显得重要。本文通过LabVIEW软件&#xff0c;展开液压振动锤启停共振控制技术的研究与应用&#xff0c;探讨如何通过改进控制系统来优化液压振动锤的工作性能&#xff0c;确保其在复杂工况下的稳定性与效率。 ​ …...

Slidev使用(一)安装

文章目录 1. **安装位置**2. **使用方式**3. **适用场景**4. **管理和维护** 全局安装1. **检查 Node.js 和 npm 是否已安装**2. **全局安装 Slidev CLI**3. **验证安装是否成功**4. **创建幻灯片文件**5. **启动 Slidev**6. **实时编辑和预览**7. **构建和导出&#xff08;可选…...

浙大:DeepSeek技术溯源及前沿探索

浙江大学DS系列专题《DeepSeek技术溯源及前沿探索》由朱强教授主讲&#xff0c;内容主要包括 语言模型、Transformer、ChatGPT、DeepSeek及新一代智能体 等核心主题。 下载方式&#xff1a;关注“渡江客涂鸦板”&#xff0c;回复ds1253免费获取下载地址 语言模型&#xff1a;语…...

【八股】未知宽高元素水平垂直居中的三种方法

在笔试/面试中&#xff0c;经常出现的一个问题就是&#xff1a;如何实现元素水平垂直居中&#xff1f; 本文会直接使用代码&#xff0c;介绍未知宽高元素水平垂直居中的三种方法&#xff1a; 方法一&#xff1a;绝对定位absolute //绝对定位&#xff0c;将元素的左右位置设置…...

23种设计模式-中介者(Mediator)设计模式

中介者设计模式 &#x1f6a9;什么是中介者设计模式&#xff1f;&#x1f6a9;中介者设计模式的特点&#x1f6a9;中介者设计模式的结构&#x1f6a9;中介者设计模式的优缺点&#x1f6a9;中介者设计模式的Java实现&#x1f6a9;代码总结&#x1f6a9;总结 &#x1f6a9;什么是…...