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

深度学习进阶:构建多层神经网络

在上一篇文章中,我们从零开始构建了一个简单的两层神经网络,并通过异或问题(XOR)展示了神经网络的强大能力。今天,我们将进一步深入,构建一个更复杂的多层神经网络,并引入更多高级概念,如多隐藏层、激活函数选择、正则化等。我们还会使用更复杂的分类任务来训练模型,并评估其性能。

1. 多层神经网络的结构

在实际应用中,深度学习模型通常包含多个隐藏层,这种结构被称为深度神经网络(DNN)。多层神经网络能够学习更复杂的特征表示,从而更好地处理复杂的任务,如图像分类、语音识别等。

1.1 多隐藏层的作用

隐藏层的数量和每层的神经元数量是神经网络的重要超参数。增加隐藏层的数量可以提高模型的表达能力,但同时也可能导致训练难度增加(如梯度消失或梯度爆炸)。因此,选择合适的网络结构是深度学习中的一个重要任务。

深度学习中的“深度”

深度学习中的“深度”指的是神经网络中隐藏层的数量。更多的隐藏层意味着网络可以学习到更复杂的特征表示。例如,浅层网络可能只能学习到简单的线性或非线性特征,而深层网络可以学习到更抽象、更复杂的特征。然而,增加层数也会带来一些问题,如梯度消失和梯度爆炸,这使得训练深层网络变得更加困难。
梯度消失与梯度爆炸
梯度消失是指在反向传播过程中,梯度逐渐变小,导致靠近输入层的权重更新非常缓慢,甚至停止更新。梯度爆炸则是指梯度逐渐变大,导致权重更新过大,使得训练过程不稳定。这些问题通常出现在深层网络中,解决方法包括使用合适的激活函数(如ReLU)、权重初始化方法(如Xavier初始化)和正则化技术(如Dropout)。

1.2 激活函数的选择

激活函数是神经网络中的关键组件,它引入了非线性,使得网络能够学习复杂的模式。常用的激活函数包括:

  • Sigmoid函数:将输出限制在0到1之间,常用于二分类问题,但容易导致梯度消失。
  • ReLU函数(Rectified Linear Unit):将负值置为0,保留正值,计算简单且能有效缓解梯度消失问题。
  • Tanh函数:将输出限制在-1到1之间,输出范围更对称,但同样存在梯度消失问题。
  • Leaky ReLU:改进版的ReLU,允许负值通过一个小的斜率传递,避免了ReLU在负值区域的梯度消失问题。
  • Softmax函数:常用于多分类问题的输出层,将输出转换为概率分布。

激活函数的对比
选择合适的激活函数对模型的性能至关重要。Sigmoid和Tanh函数虽然能够引入非线性,但在深层网络中容易导致梯度消失。ReLU及其变体(如Leaky ReLU)则在深层网络中表现更好,因为它们能够有效缓解梯度消失问题。Softmax函数则专门用于多分类问题的输出层,将输出转换为概率分布,便于计算交叉熵损失。


2. 构建多层神经网络

接下来,我们将构建一个包含多个隐藏层的神经网络,并用它解决一个更复杂的分类任务。我们将使用Python和NumPy来实现这个模型。

2.1 数据准备

为了展示多层神经网络的性能,我们将使用经典的鸢尾花(Iris)数据集。这是一个包含150个样本的多分类任务,每个样本有4个特征,目标是将样本分为3个类别。

from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler, OneHotEncoder# 加载数据
iris = load_iris()
X, y = iris.data, iris.target# 数据标准化
scaler = StandardScaler()
X_scaled = scaler.fit_transform(X)# 将标签转换为独热编码
encoder = OneHotEncoder(sparse=False)
y_onehot = encoder.fit_transform(y.reshape(-1, 1))# 划分训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X_scaled, y_onehot, test_size=0.2, random_state=42)

2.2 神经网络的实现

我们将构建一个包含两个隐藏层的神经网络,每个隐藏层有10个神经元。我们将使用ReLU作为隐藏层的激活函数,Softmax作为输出层的激活函数。

import numpy as npdef relu(x):return np.maximum(0, x)def relu_derivative(x):return (x > 0).astype(float)def softmax(x):exp_x = np.exp(x - np.max(x, axis=1, keepdims=True))return exp_x / np.sum(exp_x, axis=1, keepdims=True)class MultiLayerNeuralNetwork:def __init__(self, input_size, hidden_sizes, output_size):self.input_size = input_sizeself.hidden_sizes = hidden_sizesself.output_size = output_sizeself.weights = []self.biases = []# 初始化权重和偏置sizes = [input_size] + hidden_sizes + [output_size]for i in range(len(sizes) - 1):self.weights.append(np.random.randn(sizes[i], sizes[i + 1]) * 0.01)self.biases.append(np.zeros((1, sizes[i + 1])))def forward(self, X):self.layers = [X]self.z_layers = []for i in range(len(self.weights) - 1):z = np.dot(self.layers[-1], self.weights[i]) + self.biases[i]self.z_layers.append(z)self.layers.append(relu(z))z = np.dot(self.layers[-1], self.weights[-1]) + self.biases[-1]self.z_layers.append(z)self.layers.append(softmax(z))return self.layers[-1]def compute_loss(self, y_pred, y_true):return -np.mean(y_true * np.log(y_pred + 1e-8))def backward(self, y_pred, y_true):d_loss = y_pred - y_trued_weights = []d_biases = []for i in range(len(self.weights) - 1, -1, -1):d_w = np.dot(self.layers[i].T, d_loss)d_b = np.sum(d_loss, axis=0, keepdims=True)d_weights.append(d_w)d_biases.append(d_b)if i > 0:d_loss = np.dot(d_loss, self.weights[i].T) * relu_derivative(self.z_layers[i - 1])d_weights.reverse()d_biases.reverse()return d_weights, d_biasesdef update_weights(self, d_weights, d_biases, learning_rate):for i in range(len(self.weights)):self.weights[i] -= learning_rate * d_weights[i]self.biases[i] -= learning_rate * d_biases[i]def train(self, X_train, y_train, epochs, learning_rate):for epoch in range(epochs):y_pred = self.forward(X_train)loss = self.compute_loss(y_pred, y_train)d_weights, d_biases = self.backward(y_pred, y_train)self.update_weights(d_weights, d_biases, learning_rate)if epoch % 100 == 0:print(f"Epoch {epoch}: Loss = {loss:.6f}")def predict(self, X):return np.argmax(self.forward(X), axis=1)# 创建神经网络
input_size = X_train.shape[1]
hidden_sizes = [10, 10]
output_size = y_train.shape[1]nn = MultiLayerNeuralNetwork(input_size, hidden_sizes, output_size)# 训练神经网络
nn.train(X_train, y_train, epochs=1000, learning_rate=0.01)# 测试模型
y_pred = nn.predict(X_test)
y_true = np.argmax(y_test, axis=1)
accuracy = np.mean(y_pred == y_true)
print(f"Test Accuracy: {accuracy:.4f}")

2.3 输出结果

Epoch 0: Loss = 1.103452  
Epoch 100: Loss = 0.352123  
Epoch 200: Loss = 0.289765  
...  
Test Accuracy: 0.9667

3. 模型评估与优化

在深度学习中,模型的评估和优化是至关重要的。我们通常使用以下指标来评估模型的性能:

  • 准确率(Accuracy):预测正确的样本数占总样本数的比例。
  • 召回率(Recall):模型能够正确识别的正样本数占所有正样本的比例。
  • F1分数(F1 Score):准确率和召回率的调和平均值。
    此外,我们还可以通过以下方法优化模型:
  • 正则化(Regularization):通过在损失函数中加入正则化项(如L1或L2正则化),防止模型过拟合。
  • 学习率调整(Learning Rate Scheduling):动态调整学习率,加速模型的收敛。
  • 数据增强(Data Augmentation):通过生成更多的训练数据,提高模型的泛化能力。

3.1 正则化技术

L1正则化

L1正则化通过在损失函数中加入权重的绝对值之和来惩罚权重。它可以使一些权重变为零,从而实现特征选择。L1正则化的损失函数可以表示为:
在这里插入图片描述


L2正则化

L2正则化通过在损失函数中加入权重的平方和来惩罚权重。它可以使权重保持较小的值,从而防止过拟合。L2正则化的损失函数可以表示为:
在这里插入图片描述


Dropout
Dropout是一种常用的正则化技术,它在训练过程中随机丢弃一部分神经元的输出。Dropout可以防止神经元之间的共适应,从而提高模型的泛化能力。在测试阶段,所有神经元都会被保留,但输出会乘以一个缩放因子。

3.2 学习率调整

学习率是深度学习中的一个重要超参数。合适的学习率可以使模型更快地收敛,而不合适的学习率可能导致训练过程不稳定或收敛缓慢。动态调整学习率是一种常见的策略,例如,随着训练的进行逐渐减小学习率。

学习率调度器(Learning Rate Scheduler)

学习率调度器可以根据训练的进度动态调整学习率。常见的调度策略包括:

  • 分段常数衰减:在不同的训练阶段使用不同的学习率。
  • 指数衰减:学习率随着时间指数级减小。
  • 余弦衰减:学习率按照余弦函数的形状变化。

3.3 数据增强

数据增强是通过生成更多的训练数据来提高模型的泛化能力。在图像分类任务中,常见的数据增强方法包括旋转、平移、缩放、裁剪和颜色变换。数据增强可以增加模型对输入数据的鲁棒性,从而提高模型的性能。

4. 小结

在本篇文章中,我们构建了一个包含多个隐藏层的神经网络,并用它解决了鸢尾花分类任务。我们详细介绍了多层神经网络的结构、激活函数的选择以及模型的训练过程。通过代码示例,我们展示了如何实现一个简单的多层神经网络,并评估其性能。
希望这篇文章能帮助你更好地理解深度学习的核心概念。在下一篇文章中,我们将引入深度学习框架(如TensorFlow或PyTorch),并构建更复杂的卷积神经网络(CNN),用于图像分类任务。

相关文章:

深度学习进阶:构建多层神经网络

在上一篇文章中,我们从零开始构建了一个简单的两层神经网络,并通过异或问题(XOR)展示了神经网络的强大能力。今天,我们将进一步深入,构建一个更复杂的多层神经网络,并引入更多高级概念&#xff…...

高斯消元法

前置数学知识 n元线性方程是具有如下形式的方程: a 1 x 1 a 2 x 2 a 3 x 3 … a n x n b a_1x_1a_2x_2a_3x_3…a_nx_n b a1​x1​a2​x2​a3​x3​…an​xn​b 其中, a 1 , a 2 , . . . a_1,a_2,... a1​,a2​,...以及常数项 b b b均为已知的实数…...

ubuntu 安全策略(等保)

windows 三个帐号屏保设置组策略,密码超时次数/审计记录; linux 应具有登录失败处理功能,应配置并启用结束会话、限制非法登录次数和当登录连接超时自动退出等相关措施。 1、在系统中新建测试用户,使用此用户登录时多次输入错误密码&…...

计算机毕业设计SpringBoot+Vue.js购物推荐系统网站(源码+文档+PPT+讲解)

温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...

QT线程同步

文章目录 前言1. 使用互斥锁(QMutex)2.使用QMutexLocker便利类3. 使用读写锁(QReadWriteLock)4.QReadLocker便利类和QWriteLocker便利类对QReadWriteLock进行加解锁5. 使用信号量(QSemaphore)6. 使用条件变…...

何为第一二三产业?

第一、第二、第三产业的分类是经济学中对经济活动的划分方式,起源于20世纪30年代经济学家费希尔和克拉克的理论。以下是具体说明: 第一产业(Primary Sector) 定义:直接利用自然资源进行生产活动的行业。 核心领域&…...

Spring 面试题

Autowired和Resource两个注解的区别 Autowired: 是Spring框架的注解,用于依赖注入。 默认按照类型(byType)注入,如果存在多个相同类型的Bean,则会报错。 可以通过Qualifier指定具体的Bean名称。 如果没有匹…...

Linux设备驱动开发-SPI驱动开发详解(包含设备树处理详细过程)

基础知识及 SPI 相关结构体介绍 引脚:MISO(master 输入,slave 输出),MOSI(master 输出,slave 输入),片选引脚,SCK(时钟) 控制寄存器&…...

物联网平台建设方案一

系统概述 构建物联网全域支撑服务能力,为实现学院涵盖物联网设备的全面感知、全域互联、全程智控、全域数字基底、全过程统筹管理奠定基础,为打造智能化提供坚实后台基石。 物联网平台向下接入各种传感器、终端和网关,向上通过开放的实施分…...

java23种设计模式-桥接模式

桥接模式(Bridge Pattern)学习笔记 🌟 定义 桥接模式属于结构型设计模式,将抽象部分与实现部分分离,使它们可以独立变化。通过组合代替继承的方式,解决多维度的扩展问题,防止类爆炸。 &#x…...

springboot实现文件上传到华为云的obs

一、前言 有时在项目中需要使用一些存储系统来存储文件&#xff0c;那么当项目要接入obs作为存储系统时&#xff0c;就会利用obs来进行文件的上传下载&#xff0c;具体实现如下。 二、如何通过obs实现文件的上传下载&#xff1f; 1.添加相关的obs的maven依赖。 <dependency…...

【红队利器】单文件一键结束火绒6.0

关于我们 4SecNet 团队专注于网络安全攻防研究&#xff0c;目前团队成员分布在国内多家顶级安全厂商的核心部门&#xff0c;包括安全研究领域、攻防实验室等&#xff0c;汇聚了行业内的顶尖技术力量。团队在病毒木马逆向分析、APT 追踪、破解技术、漏洞分析、红队工具开发等多个…...

DeepSeek 助力 Vue 开发:打造丝滑的滚动动画(Scroll Animations)

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…...

Compose 动画,让页面动起来

Compose 动画&#xff0c;让页面动起来 概述高级别动画APIAnimatedVisibilityMutableTransitionStateModifier.animateEnterExit自定义Enter/Exit动画 AnimatedContentContentTransform自定义动画SizeTranstion定义大小动画定义子元素动画自定义Enter/Exit动画 CrossfadeModifi…...

Windows CMD 命令大全(Complete List of Windows CMD Commands)

Windows CMD 命令大全&#xff1a; Windows CMD 是 Windows 系统内置的命令行工具&#xff0c;用于执行各种命令和管理任务。 称为Command Prompt。它提供了一个通过键入命令来与计算机系统进行交互的方式&#xff0c;类似于早期的DOS操作系统。以下是 CMD 的基础知识和常用命…...

DeepSeek在MATLAB上的部署与应用

在科技飞速发展的当下&#xff0c;人工智能与编程语言的融合不断拓展着创新边界。DeepSeek作为一款备受瞩目的大语言模型&#xff0c;其在自然语言处理领域展现出强大的能力。而MATLAB&#xff0c;作为科学计算和工程领域广泛应用的专业软件&#xff0c;拥有丰富的工具包和高效…...

IP代理在网络数据挖掘中的关键作用(AI大模型数据采集版)

在当今人工智能飞速发展的时代&#xff0c;AI大模型的训练需要海量且多样化的数据。然而&#xff0c;在数据采集过程中&#xff0c;常常面临诸多挑战&#xff0c;而IP代理在其中发挥着至关重要的作用。 数据采集的多样性是影响AI大模型性能的关键因素。如果数据来源单一&#x…...

pandas数据的导出

数据导出 将数据导出到CSV文件 数据对象.to_csv(filepath,sep"",indexFalse,encoding)参数1:文件的路径参数2:分隔符&#xff0c;默认是 ,参数3:是否保留索引 默认 Ture参数4:文件编码代码 &#xff1a; # 将数据导出到CSV # 引用 pandas import pandas as pd # 定…...

Claude-3.7-Sonnet:Cursor 的新引擎,解锁编码与推理的未来

引言 claude-3.7-sonnet 是 Anthropic 最新发布的大型语言模型&#xff0c;于 2025 年 2 月 24 日推出&#xff0c;并已集成到 Cursor AI 平台中。Cursor 是一个 AI 驱动的集成开发环境&#xff08;IDE&#xff09;&#xff0c;旨在通过 AI 增强开发者的生产力。claude-3.7-so…...

JavaScript函数-函数的两种声明方式

在JavaScript中&#xff0c;函数是构建复杂逻辑和实现代码重用的基本单元。了解如何正确地定义和使用函数对于任何JavaScript开发者来说都是至关重要的。本文将详细介绍JavaScript函数的两种主要声明方式&#xff1a;函数声明&#xff08;Function Declaration&#xff09;和函…...

微服务即时通信系统---(六)语音识别子服务

目录 功能设计 模块划分 业务接口/功能示意图 服务实现流程思想 服务代码实现 编写proto文件 服务端创建子类(SpeechRecognitionServiceImpl)完成RPC服务调用函数重写 SpeechRecognize(语音识别) 服务端完成语音识别子服务类(SpeechRecognitionServer) 注意 …...

【Java 8】Lambda表达式介绍

目录 1、Lambda简介 2、语法介绍 3、Lambda表达式示例 3.1、无参数的 Lambda 表达式 3.2、单个参数的 Lambda 表达式 3.3、多个参数的 Lambda 表达式 3.4、带语句块的 Lambda 表达式 4、Lambda使用场景 4.1、替代匿名内部类 4.2、集合操作 4.3、排序 4.4、函数式接口…...

2011-2019年各省电视节目综合人口覆盖率数据

2011-2019年各省电视节目综合人口覆盖率数据 1、时间&#xff1a;2011-2019年 2、来源&#xff1a;国家统计局、统计年鉴 3、指标&#xff1a;行政区划代码、地区、年份、电视节目综合人口覆盖率(%) 4、范围&#xff1a;31省 5、指标解释&#xff1a;电视节目综合人口覆盖…...

便捷高效的免费 PDF 文件处理帮手

​软件介绍 今天要给大家推荐一款超实用的 PDF 工具箱。它的优势十分突出&#xff0c;完全免费且没有任何使用限制。 安装起来毫不费力&#xff0c;下载完成后&#xff0c;直接打开就能使用。软件界面简洁大方&#xff0c;操作便捷顺手。其核心功能涵盖三大板块&#xff1a;一…...

DeepSeek引领目标检测新趋势:如何通过知识蒸馏优化模型性能

目录 一、知识蒸馏是什么&#xff1f; 二、知识蒸馏在目标检测中的重要性 提升实时性 跨任务迁移学习 三、如何使用知识蒸馏优化目标检测&#xff1f; 训练教师模型 生成软标签 训练学生模型 调节温度参数 多教师蒸馏&#xff08;可选&#xff09; 四、案例分享 定…...

“深入解析 SQL Server 子查询:从基础到应用”

目录 引言什么是子查询&#xff1f; 子查询的定义子查询的类型 子查询的使用 标量子查询多行子查询多列子查询相关子查询 子查询的性能优化子查询的实际案例总结 引言 在 SQL Server 中&#xff0c;子查询是一种强大的工具&#xff0c;允许我们在一个查询中嵌套另一个查询&am…...

375_C++_cloud手机推送,添加人脸告警信息到任务队列中,UploadAlarmPush是典型的工厂模式应用,为什么使用工厂模式完成这部分代码

一:AlarmFaceInfo的应用 让我帮你解析这个lambda表达式的实现: // ...................... .h ...........................// struct RsMsgPushTask_S : public Task{AlarmType_E mainAlarmType;unsigned int subAlarmType;DateTime alarmTime...

Vue进阶之AI智能助手项目(二)——项目评审与架构设计

AI智能助手项目 基于Vue的最佳实践main.tsApp.vue主应用给子应用下发功能语言language,theme设置及appStore状态管理状态管理router路由index.tspermission.ts基于Vue的最佳实践 src目录概览 api 接口,基于接口可以做 状态处理,interceptorassets/public 静态资源component…...

LambdaQueryWrapper在Mybatis-plus中的应用

LambdaQueryWrapper 是 MyBatis-Plus 中非常强大的工具&#xff0c;用于构建类型安全的查询条件。它利用 Java 的 Lambda 表达式&#xff0c;使得查询条件的编写更加简洁和直观。 public R getAppArticleCategoryPage(ParameterObject Page page,ParameterObject AppArticleCa…...

DeepSeek AI人工智能该如何学习?

人工智能&#xff08;Artificial Intelligence, AI&#xff09;是当今科技领域的热门话题&#xff0c;它涵盖了机器学习、深度学习、自然语言处理、计算机视觉等多个子领域。 作为中国科技发展的核心方向之一&#xff0c;AI在国家战略规划中占据了重要地位&#xff0c;特别是在…...

element ui的select选择框

我们首先先试一下&#xff0c;这个东西怎么玩的 <el-select v-model"select" change"changeSelect"><el-option value"香蕉"></el-option><el-option value"菠萝"></el-option><el-option value&quo…...

解决Value of type ‘AVCodecContext‘ has no member ‘channels‘ 的问题

在 FFmpeg 7.1 中,AVCodecContext 的 channels 和 channel_layout 字段已经被移除,取而代之的是 AVChannelLayout 结构。因此,代码需要进行调整以适应新的 API。 以下是如何正确设置 AVCodecContext 和 AVCodecParameters 的方法。 1. 问题分析 在 FFmpeg 7.1 中: AVCode…...

【STM32H743IIT6】STM32H7的ADC时钟频率设置问题 —— 网上大多文章未注意到的要点!

前言 我使用的是定时器触发ADC采样。最近在想达到ADC的最高采样率的时候&#xff0c;发现一直却卡在1Msps上不去&#xff0c;直到在硬汉嵌入式的论坛里才发现了答案&#xff1a;[ADC] STM32H743/H750的Y版和V版芯片ADC的主频区别 这篇文章就详细的讲一下这个问题&#xff0c;这…...

GGUF 文件格式全解析

在机器学习领域&#xff0c;模型的存储和部署一直是关键环节。随着大语言模型 (LLM) 的广泛应用&#xff0c;如何高效地存储和加载这些复杂的模型成为一个亟待解决的问题。GGUF&#xff08;GGML Universal Format&#xff09;作为一种新兴的二进制文件格式&#xff0c;旨在解决…...

剑指offer - 面试题11 旋转数组的最小数字

题目链接&#xff1a;旋转数组的最小数字 第一种&#xff1a;正确写法&#xff08;num[m]和nums[r]比较&#xff09; class Solution { public:/*** 代码中的类名、方法名、参数名已经指定&#xff0c;请勿修改&#xff0c;直接返回方法规定的值即可** * param nums int整型v…...

JNA基础使用,调用C++返回结构体

C端 test.h文件 #pragma oncestruct RespInfo {char* path;char* content;int statusCode; };extern "C" { DLL_EXPORT void readInfo(char* path, RespInfo* respInfo); }test.cpp文件 #include "test.h"void readInfo(char* path, RespInfo* respInfo…...

Typora的Github主题美化

[!note] Typora的Github主题进行一些自己喜欢的修改&#xff0c;主要包括&#xff1a;字体、代码块、表格样式 美化前&#xff1a; 美化后&#xff1a; 一、字体更换 之前便看上了「中文网字计划」的「朱雀仿宋」字体&#xff0c;于是一直想更换字体&#xff0c;奈何自己拖延症…...

计算机网络模型-TCP/IP协议簇

目录 1. OSI 参考模型 2. TCP/IP 5层协议簇 3. 数据传输过程 4. OSI模型vsTCP/IP模型 5. 工作设备和协议 1. OSI 参考模型 OSI 参考模型 OSI 参考模型 7层参考协议&#xff1a;同层使用相同协议&#xff0c;下层为上层提供服务 再往每一层填网络协议的时候&#xff0c;表…...

ros进阶——强化学习倒立摆的PG算法实现

项目地址&#xff1a;https://github.com/chan-yuu/cartpole_ws git clone https://github.com/chan-yuu/cartpole_ws依赖安装&#xff1a; xterm等 python3.8 torch等上一节中我们定义了很多ros工具&#xff0c;在这里我们将进行验证。 对于launch_robot_test.py来说&#x…...

BUU41 [GYCTF2020]FlaskApp1【SSTI】

题目&#xff1a; 加密处没啥事&#xff0c;但是解密的地方提交{{7*7}}就会返回报错界面&#xff0c;顺便把代码也爆出来了 text_decode base64.b64decode(text.encode()) 先将字符串 text编码为字节对象&#xff0c;然后使用 base64.b64decode 函数对这个字节对象进行 Base…...

pandas读取数据

pandas读取数据 导入需要的包 import pandas as pd import numpy as np import warnings import oswarnings.filterwarnings(ignore)读取纯文本文件 pd.read_csv 使用默认的标题行、逗号分隔符 import pandas as pd fpath "./datas/ml-latest-small/ratings.csv" 使…...

React + TypeScript 全栈开发最佳实践

React TypeScript 全栈开发最佳实践 一、环境搭建与项目初始化 node.js和npm的安装请参考我的文章。 1.1 脚手架选择与工程创建 # 使用Vite 5.x创建ReactTS项目&#xff08;2025年主流方案&#xff09; npx create-vitelatest my-app --template react-ts cd my-app npm in…...

RK3399 Android7双WiFi功能实现

在Android系统里面,WiFi功能STA和AP模式是互斥的,而现在越来越多的WiFi模组或者芯片能支持并发模式,即STA+P2P、STA+STA或者STA+AP模式组合。不管是单WiFi并发,还是双WiFi模组,想让STA和AP两个模式同时运行,对于Android7来说,是需要修改到系统源码,才能让APP层用Androi…...

前端包管理工具进化论:npm vs yarn vs pnpm 深度对比

前端包管理工具进化论&#xff1a;npm vs yarn vs pnpm 深度对比 一、工具定位与核心差异二、功能特性对比三、优缺点深度解析四、性能实测对比&#xff08;示例数据&#xff09;五、选型建议六、未来趋势 一、工具定位与核心差异 npm (Node Package Manager) Node.js 官方捆绑…...

绕过information_schema与order by注入以及seacsmv9注入

一:information_schema绕过 1,、sys数据库包含了许多视图&#xff0c;这些视图整合了来自information_schema和performance_schema的数据&#xff0c;攻击者可以利用这些视图来获取数据库结构信息。 -- 获取所有数据库名 SELECT DISTINCT table_schema FROM sys.schema_table_…...

在LangFlow中集成OpenAI Compatible API类型的大语言模型

一、背景与核心价值 从Dify换到这个langflow真的时各种的不适应啊。 就比如这个OpenAI Compatible API,这不应该是基本操作嘛? 算了,服了,习惯了就好了。咱闲言少叙,正片开始: LangFlow作为LangChain的可视化开发工具,其最大优势在于无需编写代码即可构建复杂的大模型…...

PING命令TTL解析

在 ping 命令中&#xff0c;TTL&#xff08;Time to Live&#xff0c;生存时间&#xff09; 是 IP 数据包的核心字段之一&#xff0c;用于控制数据包在网络中的生命周期。以下是针对 TTL 的简明解析&#xff1a; 1. TTL 的核心作用 防循环机制&#xff1a;TTL 是一个计数器&a…...

Hadoop 基础原理

Hadoop 基础原理 基本介绍Hadoop 的必要性Hadoop 核心组件Hadoop 生态系统中的附加组件 HDFSHDFS 集群架构HDFS 读写流程HDFS 写流程HDFS 读流程 NameNode 持久化机制 MapReduce底层原理示例 Hadoop 是一个由 Apache 基金会开发的分布式系统基础架构&#xff0c;主要解决海量数…...

蓝桥杯单片机基础部分——1.5基础模块代码升级

前言 之前的蓝桥杯单片机基础部分——1、基础模块代码发现有的同学不太会使&#xff0c;这样的话就给他们都封装一下函数&#xff0c;额外封装一下蜂鸣器和继电器&#xff0c;这就全了&#xff0c;到时候的逻辑只要没问题就没啥事了 LED灯模块 现在&#xff0c;给这里封装一个…...

PyTorch常用函数总结(持续更新)

本文主要记录自己在用 PyTorch复现经典模型 过程中遇到的一些函数及用法&#xff0c;以期对 常见PyTorch函数 更加熟练~ 官方Docs&#xff1a;PyTorch documentation — PyTorch 2.6 documentation 目录 数据层面 torch.sign(tensor) torch.tensor(np.eye(3)[y]) torch.on…...