范式之殇-关系代数与参照完整性在 Web 后台的落寞
最近参加了一个PostgreSQL相关的茶会,感慨良多。原本话题是PostgreSQL 在 SELECT 场景中凭借其成熟的查询优化器、丰富的功能特性和灵活的执行策略,展现出显著优势。在窗口函数(Window Functions)、JOIN 优化、公共表表达式(WITH/CTE) 等核心功能中,支持严格的关系代数和范式约束下的复杂查询。结果后来,就跑题了,原因是有人提出这些特性其实用的极少。
笔者饶有兴趣地听完了全程,很感慨。本文就围绕 “范式之殇 - 关系代数与参照完整性在 Web 后台的落寞” 这一主题,简要探讨当下 WebApp 后端数据库设计中存在的现象与问题。
如今,我们看到大量 WebApp 的后端数据库背离了传统关系型数据库设计的核心原则,出现简单表结构、字段冗余、参照完整性缺失等情况,数据库系统强大的外键、检查等特性被忽视,大量的一致性检查交给Python后台而不是DBMS本身。这是一种慵懒,还是因为新的数据和应用环境催生的工程妥协?
一、现象剖析:背离传统设计原则的 Web 后台数据库
在传统的关系型数据库理论中,关系代数是数据处理的基石,它定义了选择、投影、连接等一系列操作,确保数据在不同表之间以规范化的方式关联与处理。参照完整性则通过外键约束等机制,保障数据的一致性和准确性,避免孤立数据与无效关联。然而在当下的 WebApp 后端数据库里,这些理论与机制却逐渐失去了用武之地。
以常见的电商应用为例,按照规范设计,商品表、订单表、用户表之间应通过外键建立明确关联,保证订单引用的商品和用户信息真实有效。但实际情况却是,许多开发者为减少表连接操作,在订单表中冗余商品名称、用户姓名等信息,导致数据更新时极易出现不一致问题。同时,由于缺失外键约束,订单表可能存在引用不存在的商品 ID 或用户 ID 的情况,造成数据混乱。在社交媒体应用中,用户发布的动态、评论等数据,也常常忽视参照完整性,让数据维护变得异常困难。
二、范式案例:教科书三范式在实际应用中的困境
在关系型数据库设计中,范式是衡量数据库结构合理性的重要标准,其中三范式(3NF)要求数据库表中非主属性不存在对码的传递依赖。以一个在线教育系统为例,最初设计有一张 “课程信息表”,包含字段:课程 ID(主键)、课程名称、教师 ID、教师姓名、教师联系方式。在这个表中,教师姓名和教师联系方式并不直接依赖于课程 ID,而是通过教师 ID 间接依赖,这就违反了三范式。以下是违反三范式的 “课程信息表” 结构:
字段名 | 类型 | 备注 |
---|---|---|
课程 ID | 主键 | 唯一标识课程 |
课程名称 | 课程的名称 | |
教师 ID | 标识授课教师 | |
教师姓名 | 教师的姓名 | |
教师联系方式 | 教师的联系方式 |
为了满足三范式,我们需要将教师相关信息拆分出来,新建 “教师表”,包含教师 ID(主键)、教师姓名、教师联系方式;“课程信息表” 则保留课程 ID(主键)、课程名称、教师 ID,通过教师 ID 与 “教师表” 建立关联。
满足三范式后的 “课程信息表” 结构:
字段名 | 类型 | 备注 |
---|---|---|
课程 ID | 主键 | 唯一标识课程 |
课程名称 | 课程的名称 | |
教师 ID | 标识授课教师,关联 “教师表” 的教师 ID |
满足三范式后的 “教师表” 结构:
字段名 | 类型 | 备注 |
---|---|---|
教师 ID | 主键 | 唯一标识教师 |
教师姓名 | 教师的姓名 | |
教师联系方式 | 教师的联系方式 |
这种遵循三范式的设计在传统单机数据库中能有效减少数据冗余,保证数据的一致性。但在分布式数据库和大数据场景下,却暴露出诸多问题。
在分布式数据库中,数据分散存储在多个节点上,上述三范式设计会导致大量的跨节点表连接操作。例如,当查询某课程及其授课教师信息时,需要在 “课程信息表” 所在节点和 “教师表” 所在节点之间进行数据传输与连接,这不仅增加了网络开销,还降低了查询效率,严重影响系统性能。而在大数据场景中,数据处理强调的是快速读取和分析海量数据,三范式严格的规范化设计使得数据分散在多个表中,在进行复杂的数据分析任务,如统计不同教师的课程数量及学生反馈情况时,需要进行大量的多表连接操作,这无疑增加了数据处理的复杂性和时间成本,难以满足大数据实时性和高效性的要求。
三、现象缘由:开发效率与业务需求的权衡
(一)追求快速开发与迭代
在互联网行业 “唯快不破” 的竞争环境下,快速开发和迭代成为 WebApp 开发的首要目标。传统的关系型数据库设计,尤其是遵循严格范式和参照完整性原则的设计,需要花费大量时间进行数据库建模、表结构设计以及关系约束的定义。相比之下,采用简单的表结构和字段冗余策略,开发者可以更快速地搭建起数据库基础架构,满足业务初期的快速上线需求。例如,一些初创公司在开发初期,为了能在短时间内将产品推向市场,会选择牺牲数据库设计的规范性,优先实现功能。
(二)应对复杂多变的业务需求
WebApp 的业务需求往往具有高度的不确定性和快速变化的特点。新功能的不断添加、业务流程的频繁调整,使得严格遵循范式的数据库设计难以适应。当需要对业务逻辑进行修改时,调整具有复杂关系约束和范式规范的数据库结构成本极高,不仅需要修改表结构,还可能涉及到外键、触发器等一系列的调整。而简单的表结构和冗余字段,在应对业务变化时更加灵活,开发者可以直接在表中添加或修改字段,通过后端代码来实现业务逻辑的调整,无需过多考虑数据库结构的完整性和一致性。
(三)开发团队技术认知与习惯
部分开发团队对关系型数据库的高级特性缺乏深入理解和熟练运用,更倾向于使用自己熟悉的后端代码来处理数据关系和约束。Python 作为一种广泛应用于 Web 开发的编程语言,具有简洁易用、生态丰富的特点,很多开发者习惯通过 Python 代码实现数据的增删改查以及关系维护。例如,使用 Django、Flask 等框架的 ORM(对象关系映射)功能,虽然方便快捷,但在一定程度上掩盖了数据库底层的关系代数和参照完整性机制,导致开发者对数据库原生特性的依赖降低。
四、深层次原因:技术生态与行业发展的影响
(一)非关系型数据库的冲击
近年来,非关系型数据库(NoSQL)的兴起对传统关系型数据库造成了巨大冲击。NoSQL 数据库以其灵活的数据模型、高可扩展性和高性能等特点,在处理海量数据、高并发访问等场景下展现出独特优势。像 MongoDB 这样的文档型数据库,采用类似 JSON 的文档结构存储数据,无需事先定义严格的表结构,非常适合快速变化的业务需求。Redis 作为键值对数据库,在缓存、实时计算等场景中得到广泛应用。这些非关系型数据库的出现,让开发者在数据库选型时有了更多选择,也促使他们在 WebApp 开发中尝试打破传统关系型数据库的设计范式,选择更灵活的方案。
(二)分布式架构与微服务的普及
随着分布式架构和微服务的普及,WebApp 的后端架构变得越来越复杂。在微服务架构中,每个服务都有自己独立的数据库,服务之间通过 API 进行通信。这种架构模式下,数据的一致性和完整性维护面临更大挑战。为了降低服务之间的耦合度,减少跨服务的数据交互,各个微服务的数据库往往采用相对独立和简单的设计,难以实现全局的关系代数和参照完整性约束。例如,一个电商系统拆分为用户服务、商品服务、订单服务等多个微服务,每个服务的数据库各自独立设计,用户表、商品表、订单表之间的关系难以通过传统的数据库约束来维护,更多地依赖于服务间的接口调用和业务逻辑处理。
(三)行业人才培养与技术导向
当前计算机教育和技术培训体系中,对关系型数据库高级特性的教学和实践相对不足。很多开发者在学习过程中,更注重后端框架和编程语言的使用,对数据库设计和优化缺乏深入学习。同时,行业内对技术的评价和导向也更倾向于功能实现的速度和创新性,忽视了数据库设计的规范性和性能优化。这种人才培养和技术导向的偏差,导致开发团队在实际项目中难以充分发挥关系型数据库的强大功能,进而选择更简单但不规范的数据库设计方案。
五、总结与展望
范式之殇,反映出关系代数与参照完整性在 Web 后台逐渐落寞的现状,这是多种因素共同作用的结果。虽然当前这种现象在 WebApp 开发中较为普遍,但我们不能因此否定关系型数据库及其核心设计理念的价值。在一些对数据一致性、准确性要求较高的场景,如金融、医疗等领域,严格遵循范式和参照完整性原则的数据库设计依然不可或缺。
未来,随着技术的不断发展,我们或许可以探索出更有效的解决方案,平衡快速开发与规范设计之间的矛盾。例如,结合人工智能和自动化工具,实现数据库设计的智能优化和自动维护;进一步完善微服务架构下的数据一致性保障机制等。
相关文章:
范式之殇-关系代数与参照完整性在 Web 后台的落寞
最近参加了一个PostgreSQL相关的茶会,感慨良多。原本话题是PostgreSQL 在 SELECT 场景中凭借其成熟的查询优化器、丰富的功能特性和灵活的执行策略,展现出显著优势。在窗口函数(Window Functions)、JOIN 优化、公共表表达式&#…...
CST矩形喇叭建模
本文介绍了在电磁仿真软件中创建喇叭天线模型的基本步骤。 点击工具栏的Basic Shapes > Brick创建两个长方体(波导部分和喇叭横截面) 点击相对的两个平面,选择Loft命令进行渐变连接 将三者boolen合并 挖去中间实体,先后选…...
Python MNE-Python 脑功能磁共振数据分析
一、什么是Python MNE-Python 脑功能磁共振数据分析 为大脑功能磁共振成像数据分析工具,致力于为神经科学研究提供便捷、高效的数据分析处理工具。MNE-Python提供了处理和分析脑电图(EEG)、…...
JVM之内存管理(一)
部分内容来源:JavaGuide二哥Java 图解JVM内存结构 内存管理快速复习 栈帧:局部变量表,动态链接(符号引用转为真实引用),操作数栈(存储中间结算结果),方法返回地址 运行时…...
【AI入门】CherryStudio入门7:引入魔搭中的MCP服务
前言 来吧,继续CherryStudio的实践,前边给Cherry Studio添加知识库,对接思源笔记,以及obsidian笔记,设置了mcp-auto-install 自动安装包服务,本节让我们把魔搭中的MCP服务同步过来😄Ƕ…...
高性能Python Web 框架--FastAPI 学习「基础 → 进阶 → 生产级」
以下是针对 FastAPI 的保姆级教程,包含核心概念、完整案例和关键注意事项,采用「基础 → 进阶 → 生产级」的三阶段教学法: 一、FastAPI介绍 FastAPI 是一个现代化的、高性能的 Python Web 框架,专门用于构建 APIs(应…...
python小区物业管理系统-小区物业报修系统
目录 技术栈介绍具体实现截图系统设计研究方法:设计步骤设计流程核心代码部分展示研究方法详细视频演示试验方案论文大纲源码获取/详细视频演示 技术栈介绍 Django-SpringBoot-php-Node.js-flask 本课题的研究方法和研究步骤基本合理,难度适中…...
YOLO数据集标注工具LabelImg(打包Exe版本及使用)
前言: 在计算机视觉领域,YOLO(You Only Look Once)系列算法因其出色的实时目标检测性能而广受欢迎。然而,要训练一个精准的YOLO模型,高质量的数据标注(labling)是不可或缺的基础工作。 LabelImage 是一个开源的图像标注工具&…...
【NCCL】DBT算法(double binary tree,双二叉树)
目录 前言 ring 不足,需要 tree 朴素二叉tree只利用了一半带宽,需要 双二叉 tree 双二叉树的构造 ringvs 双二叉树 测试 ring和tree的选择 nccl tree tree搜索 基本概念解释 最大化局部性构建二叉树的方式 这种构建方式的好处 示例说明 前言…...
Java大师成长计划之第16天:高级并发工具类
📢 友情提示: 本文由银河易创AI(https://ai.eaigx.com)平台gpt-4o-mini模型辅助创作完成,旨在提供灵感参考与技术分享,文中关键数据、代码与结论建议通过官方渠道验证。 在现代Java应用中,处理并…...
【C/C++】C语⾔内存函数
C语言内存函数 1. memcpy使用和模拟实现 memcpy可以代替strcpy void * memcpy ( void * destination, const void * source, size_t num );//void*来接受任意指针,size_t 单位是字节 //memcpy的头文件为<string.h> mem是memory的缩写 是内存的意思功能: …...
SQL JOIN 关联条件和 where 条件的异同
Inner join 对于 inner join,条件写到 on 和 where 部分是一样的。 select count(1) from web_site join web_page on web_site_skwp_web_page_id where web_cityPleasant Hill and wp_access_date_sk1;输出 0select count(1)from web_site join web_page on web…...
kotlin 数据类
一 kotlin数据类与java普通类区别 Kotlin 的 data class 与 Java 中的普通类(POJO)相比,确实大大减少了样板代码(boilerplate),但它的优势不止于自动生成 getter/setter、copy()、equals()、toString()&am…...
云效 MCP Server:AI 驱动的研发协作新范式
作者:黄博文、李晔彬 云效 MCP Server 是什么? 云效 MCP(Model Context Protocol)是阿里云云效平台推出的模型上下文协议标准化接口系统,作为连接 AI 助手与 DevOps 平台的核心桥梁,通过模型上下文协议将…...
复合机器人案例启示:富唯智能如何以模块化创新引领工业自动化新标杆
在国产工业机器人加速突围的浪潮中,富唯智能复合机器人案例凭借其高精度焊接与智能控制技术,成为行业标杆。然而,随着制造业对柔性化、全场景协作需求的升级,复合机器人正从单一功能向多模态协同进化。作为这一领域的创新者&#…...
信息系统项目管理师-软考高级(软考高项)2025最新(十三)(1)
个人笔记整理---仅供参考 信息系统项目理师-软考高级(软考高项)2025最新(十三)(1)第十三章项目资源管理 13.0资源管理概述 13.1管理基础 团队发展阶段背下来 13.2项目资源管理过程 13.3规划资源管...
archlinux 详解系统层面
Arch Linux 深度解析:从设计哲学到系统架构 一、Arch Linux 概述:滚动发行的极客之选 Arch Linux 是一款以 滚动更新(Rolling Release) 为核心特性的 Linux 发行版,强调 轻量、灵活、高度可定制,旨在让用…...
⭐️⭐️⭐️【课时1:大模型是什么?】学习总结 ⭐️⭐️⭐️ for《大模型Clouder认证:基于百炼平台构建智能体应用》认证
一、学习目标 概要 通过学习《课时1:大模型是什么?》,全面了解大模型的基础概念、核心特点、发展脉络及阿里云在大模型领域的布局,为后续基于百炼平台构建智能体应用的实践操作打下坚实的理论基础。 具体目标列表 理解人工智能到大模型的演变逻辑,明确大模型在AI发展历…...
qxl显卡与spice模块笔记
1、qxl虚拟显卡设备创建QemuConsole,并保存在全局变量consoles链表中。 static void qxl_realize_primary(PCIDevice *dev, Error **errp) {PCIQXLDevice *qxl PCI_QXL(dev);VGACommonState *vga &qxl->vga;Error *local_err NULL;qxl_init_ramsize(qxl)…...
Rust 官方文档:人话版翻译指南
鉴于大部分翻译文档都不太会说人话,本专栏主要内容为 rust 程序设计语言、rust 参考手册、std 库 等官方文档的中译中。...
切比雪夫不等式专题习题解析
切比雪夫不等式专题习题解析 前言 本文为概率论习题集专栏的切比雪夫不等式专题习题解析,针对习题篇中的10道题目提供详细解答。希望通过这些解析帮助大家深入理解切比雪夫不等式的应用和意义。 一、基础概念题解析 习题1解析: 错误。切比雪夫不等式适用于任何具有有限方…...
LearnOpenGL01:创建项目
基于LearnOpenGL 相关链接: 工程搭建 hello window 环境 UBUNTU GLFW3.3:负责创建窗口处理输入 GLAD:根据不同操作系统加载不同的OPENGL函数实现 安装GLFW以及编译项 sudo apt update sudo apt install cmake build-essential libglfw3-…...
基于论文《大规模电动汽车充换电设施可调能力聚合评估与预测》开发者说明文档
real_data_model.m 开发者说明文档 脚本概述 本MATLAB脚本实现了基于论文《大规模电动汽车充换电设施可调能力聚合评估与预测》(鲍志远,胡泽春)中提出的预测模型和评估方法。脚本使用真实的充电数据、天气数据和分时电价数据,实现了LSTM与线性模型混合…...
优雅草星云智控系统产品发布会前瞻:SNMP协议全设备开启指南-优雅草卓伊凡
优雅草星云智控系统产品发布会前瞻:SNMP协议全设备开启指南-优雅草卓伊凡 一、发布会重磅预告 1.1 星云智控系统发布会详情 优雅草科技将于2024年5月15日在成都市双流区天府国际生物城会议中心举办”星云智控系统产品发布会“。作为优雅草科技CTO,卓伊…...
【Python】Pycharm中安装库可靠的方法
博主需要在pycharm中安装Python需要的库,发现可以通过两个方法,一个是在terminal中安装,如下图: 另一个,是通过软件包安装。 博主发现,保险起见,还是通过软件包安装会比较稳妥。博主遇见一个库&…...
探索Stream流:高效数据处理的秘密武器
不可变集合 stream流 Stream流的使用步骤: 先得到一条Stream流(流水线),并把数据放上去 使用中间方法对流水线上的数据进行操作 使用终结方法对流水线上的数据进行操作 Stream流的中间方法 注意1:中间方法࿰…...
Debezium RelationalSnapshotChangeEventSource详解
Debezium RelationalSnapshotChangeEventSource详解 1. 类的作用与功能 1.1 核心功能 RelationalSnapshotChangeEventSource是Debezium中用于关系型数据库快照的核心抽象类,主要负责: 数据快照:对数据库表进行全量数据快照模式捕获:捕获数据库表结构事务管理:确保快照过…...
Open CASCADE学习|实现裁剪操作
1. 引言 Open CASCADE (简称OCC) 是一个功能强大的开源几何建模内核,广泛应用于CAD/CAM/CAE领域。裁剪操作作为几何建模中的基础功能,在模型编辑、布尔运算、几何分析等方面有着重要作用。本文将全面探讨Open CASCADE中的裁剪操作实现原理、应用场景及具…...
Microsoft Azure DevOps针对Angular项目创建build版本的yaml
Azure DevOps针对Angular项目创建build版本的yaml,并通过变量控制相应job的执行与否。 注意事项:代码前面的空格是通过Tab控制的而不是通过Space控制的。 yaml文件中包含一下内容: 1. 自动触发build 通过指定code branch使提交到此代码库的…...
Navicat 17最新保姆级安装教程(附安装包+永久使用方法)
前言 Navicat Premium 是一套可创建多个连接的数据库开发工具,让你从单一应用程序中同时连接 MySQL、MariaDB、MongoDB、SQL Server、Oracle、PostgreSQL 和 SQLite 。它与 OceanBase 数据库及 Amazon RDS、Amazon Aurora、Amazon Redshift、Microsoft Azure、Orac…...
在 Kotlin 中什么是委托属性,简要说说其使用场景和原理
在 Kotlin 中,属性委托和类委托是两种通过 by 关键字实现的强大特性,它们通过“委托”机制将行为或实现逻辑委托给其他对象,从而实现代码的复用和解耦。 1 属性委托 定义: 允许把属性的 get 和 set 方法的具体实现委托给另一个对…...
[Windows] 东芝存储诊断工具1.30.8920(20170601)
[Windows] 东芝存储诊断工具 链接:https://pan.xunlei.com/s/VOPpMjGdWZOLceIjxLNiIsIEA1?pwduute# 适用型号 东芝消费类存储产品: 外置硬盘:Canvio 系列 内置硬盘:HDW****(E300 / N300 / P300 / S300 / V300 / X30…...
按位段拼接十六进制
需求: 给一组位段及对应的值,拼接出该十六进制值。 如, [15] : 0x1 [31:16] : 0xfafa [14:1] : 0x1af0 [0:0] : 0x1 def parse_range(range_str):"""解析位段字符串,返回高位和低位"""parts…...
FPGA 41 ,ICMP 协议详细解析之构建网络诊断系统( ICMP 协议与 IP 协议理论详细解析 )
目录 前言 一、ICMP协议介绍 1.1 ICMP协议介绍 1.2 ICMP报文格式 1.3 ICMP地位流程 1.4 为何需要ICMP差错报文 1.5 协议关系 二、FPGA 与 ICMP 2.1 平台选择与环境搭建 2.2 模块化设计 2.3 ICMP 功能设计 (1)ICMP 报文解析 (2&am…...
每天批次导入 100 万对账数据到 MySQL 时出现死锁
一、死锁原因及优化策略 1.1 死锁原因分析 批量插入事务过大: Spring Batch 默认将整个 chunk(批量数据块)作为一个事务提交,100 万数据可能导致事务过长,增加锁竞争。 并发写入冲突: 多个线程或批处理作…...
滑动窗口-窗口中的最大/小值-单调队列
求窗口的最大值 #include <iostream> //滑动窗口最大值用单调队列q[],q存储候选最大值的下标 //队列头是最大值的下标 using namespace std; const int N100010; int nums[N],q[N]; int hh0,tt-1;// hh 是队头指针,tt 是队尾指针,初始…...
Docker Compose 部署 MeiliSearch 指南
Docker Compose 部署 MeiliSearch 指南 目录 环境准备创建 MeiliSearch 配置文件启动 MeiliSearch 服务验证服务状态访问 MeiliSearch安全及防火墙设置...
在 MyBatis 中实现控制台输出 SQL 参数
在 MyBatis 中实现控制台输出 SQL 参数,可通过以下方案实现: # 一、使用 MyBatis-Plus 的 SqlLogInterceptor(推荐) 适用场景:项目已集成 MyBatis-Plus(3.5.3版本) 配置步骤ÿ…...
【MySQL】数据库、数据表的基本操作
个人主页:Guiat 归属专栏:MySQL 文章目录 1. MySQL基础命令1.1 连接MySQL1.2 基本命令概览 2. 数据库操作2.1 创建数据库2.2 查看数据库2.3 选择数据库2.4 修改数据库2.5 删除数据库2.6 数据库备份与恢复 3. 表操作基础3.1 创建表3.2 查看表信息3.3 创建…...
Java中的内部类详解
目录 什么是内部类? 生活中的内部类例子 为什么需要内部类? 生活中的例子 内部类的存在意义 内部类的分类 1. 成员内部类 什么是成员内部类? 成员内部类的特点 如何使用成员内部类? 成员内部类访问外部类同名成员 2. …...
【LangChain全栈开发指南】从LLM集成到智能体系统构建
目录 🌟 前言🏗️ 技术背景与价值💢 当前技术痛点🛠️ 解决方案概述👥 目标读者说明 🔍 一、技术原理剖析📊 核心概念图解💡 核心作用讲解🧩 关键技术模块说明⚖️ 技术选…...
《内存单位:解锁数字世界的“度量衡”》
🚀个人主页:BabyZZの秘密日记 📖收入专栏:C语言 🌍文章目入 一、基础单位:字节(Byte)二、进阶单位:千字节(KB)、兆字节(MB)…...
Spring Boot + MyBatis-Plus 高并发读写分离实战
引言 在高并发场景下,单一数据库实例往往成为性能瓶颈。数据库读写分离通过将读操作和写操作分配到不同的数据库实例,有效缓解主库压力,提升系统吞吐量。MyBatis-Plus 作为一款强大的持久层框架,结合 Spring Boot 能够轻松实现读…...
STC32G12K128-旋转编码器-软件去抖
STC32G12K128-旋转编码器-软件去抖 简介代码 简介 EC11旋转编码器是一种可以连续旋转的器件A,B,C为旋转编码引脚,带按键的有D,E引脚。引脚功能: A:编码器A相;B:编码器B相;C:公共端-一般接到GN…...
第J7周:对于ResNeXt-50算法的思考
目录 思考 一、代码功能分析 1. 构建 shortcut 分支(残差连接的旁路) 2. 主路径的第一层卷积(11) 4. 主路径的第三层卷积(11) 5. 残差连接 激活函数 二、问题分析总结:残差结构中通道数不一致的…...
古方焕新潮!李良济盒马联名养生水,以创新赋能中式养生新潮流
今天下午,中华老字号李良济与新零售巨头盒马联名的“五汁饮&暑清元气水”新品发布会,在李良济隆重举行。 新品发布会上,盒马与多家媒体齐聚李良济,通过中医文化体验、新品品鉴、生产全链路探秘、媒体采访等环节,不…...
使用PyTorch训练马里奥强化学习代理的完整指南
以下是使用PyTorch训练马里奥强化学习代理的完整指南,涵盖依赖库配置、环境搭建、核心代码实现及输出结果分析,结合关键优化策略与实战经验。 一、依赖库配置 基础环境安装 # 使用Anaconda创建虚拟环境(推荐) conda create -n m…...
STM32F103RCT6 + MFC实现网口设备搜索、修改IP、固件升级等功能
资源下载链接:https://download.csdn.net/download/qq_35831134/90712875?spm=1001.2014.3001.5501 一.大概逻辑: // 网口搜索大概逻辑: // ************************************************************************** // 一.环境: // 上位机用MFC下位机用STM32F103R…...
ch09 课堂参考代码
ch09 拓扑排序与基环树 拓扑排序 在一些场景中,需要完成一系列事情,这些事情之间有顺序关系或者依赖关系,在做一件事情之前必须先做另一件事,例如课程学习的先后顺序,这类问题可以抽象为图论中的拓扑排序问题。 拓扑…...
Day 15 训练
Day 15 对鸢尾花数据集进行处理,特征可视化,贝叶斯优化随机森林,Shap解释1. 导入必要的库2. 设置中文字体3. 加载数据集4. 查看数据5. 数据准备6. 贝叶斯优化随机森林7. 评估结果8. 绘制箱形图9. 绘制特征相关性热力图10. SHAP模型解释总结 对…...