sysfs 设备模型
- 介绍
Sysfs 设备文件系统与proc是同一类的文件系统,基于ramfs实现的内存文件系统。
1.1 为什么会有 sysfs? - procfs 的局限性:
- 早期,Linux 使用 procfs 来提供内核与用户空间的交互接口。
- 但 procfs 的设计不够层次化,设备信息和其他系统信息混杂在一起,显得混乱。
- 于是,开发者决定创建一个新的文件系统,专门用来管理设备和硬件信息。
- sysfs 的诞生:
- 最初,这个新文件系统叫 ddfs(Device Driver Filesystem),后来改名为 driverfs。
- 在 Linux 2.6 中,引入了 kobject 子系统,抛弃了原来基于 ramfs 的实现方式。
- 最终,driverfs 被正式更名为 sysfs,并挂载在 /sys 目录下。
1.2 sysfs 的作用是什么?
- 展示设备信息:
- sysfs 提供了一个清晰、有层次的目录结构,展示了系统的设备、总线、驱动等信息。
- 比如,所有块设备的信息会放在 /sys/block,网络设备的信息会放在 /sys/class/net。
- 用户与内核的桥梁:
- 和 procfs 类似,sysfs 允许用户通过简单的命令(如 cat 或 echo)来查看或修改内核中的信息。
- 例如,可以通过 cat /sys/class/net/eth0/address 查看网卡的 MAC 地址。
- 硬件拓扑的映射:
- 系统中所有的设备和总线都通过 kobject 组织起来,sysfs 将这些关系直接反映到文件系统中。
- 用户可以通过 /sys 目录轻松了解硬件的拓扑结构。
uangmang@ubuntu /sys [127]> ls
block/ bus/ class/ dev/ devices/ firmware/ fs/ hypervisor/ kernel/ module/ power/
1. block/
作用:包含系统中所有的块设备信息(如硬盘、分区等)。
示例:/sys/block/sda/ 对应第一块 SATA 硬盘。
2. bus/
作用:按总线类型(如 PCI、USB、I2C 等)分类的设备列表。
示例:/sys/bus/usb/devices/ 包含所有 USB 设备。
3. class/
作用:按设备功能分类的视图(如网卡、显卡、输入设备等)。
示例:/sys/class/net/ 包含所有网络接口。
4. dev/
作用:提供字符设备和块设备的符号链接,指向实际设备节点。
示例:/sys/dev/block/ 和 /sys/dev/char/ 分别对应块设备和字符设备的主次设备号。
5. devices/
作用:系统所有设备的物理层次结构,反映硬件实际连接方式。
示例:PCI 设备会显示为 /sys/devices/pci0000:00/。
6. firmware/
作用:固件相关信息和接口(如 ACPI、EFI 等)。
示例:ACPI 表可通过此目录访问。
7. fs/
作用:文件系统相关信息(如挂载的文件系统、配额等)。
示例:/sys/fs/ext4/ 包含 ext4 文件系统的参数。
8. hypervisor/
作用:虚拟化相关信息和配置(如 Xen、KVM 等虚拟化平台)。
示例:Xen 虚拟机的属性可能在此目录下。
9. kernel/
作用:内核运行时参数和配置(如调试选项、热插拔设置等)。
示例:/sys/kernel/debug/ 提供调试接口(需挂载 debugfs)。
10. module/
作用:已加载内核模块的信息和参数。
示例:/sys/module/ext4/ 包含 ext4 文件系统模块的参数。
11. power/
作用:电源管理相关配置(如休眠、唤醒事件等)。
示例:/sys/power/state 可写入 mem 进入睡眠状态。
- 对象
Linux是以一切皆文件的哲学,sysfs 保留给用户操作的接口,是用户通向内核的窗户。在 Linux 内核中,kobject、kobj_type 和 kset 是 设备模型(Device Model) 的核心数据结构,它们共同构成了 /sys 文件系统的底层框架。
暂时无法在飞书文档外展示此内容 - 相关代码
3.1 Kobject
kobject
设备模型实现的中心为kobject,kobject提供了这些对象作: - reference count
- 管理对象的链接串行(集合)
- 集合的 spinlock
- 将对象属性导出到用户空间(通过sysfs)
/include/linux/kobject.h
struct kobject {const char *name; // 物件的文字名稱,可利用 sysfs 導出至 user spacestruct list_head entry; // 雙向鏈結串列,用於將若干 kobject 放置到一個鏈結串列中struct kobject *parent; // 用於 kobject 的階層結構struct kset *kset; // 用於將物件與其他物件放置到一個集合時struct kobj_type *ktype; // 提供包含 kobject 的資料結構的更多詳細資訊struct sysfs_dirent *sd; // 用於 kobject 與 sysfs 間的關聯struct kref kref; // 管理 reference countunsigned int state_initialized : 1; // 是否已經初始化unsigned int state_in_sysfs : 1; // 是否已在 sysfs 呈現unsigned int state_add_uevent_sent : 1; // 紀錄 add uevent 是否發送unsigned int state_remove_uevent_sent : 1; // 若有 add uevent 沒有 remove uevent 會補發 remove ueventunsigned int uevent_suppress : 1; // 若為 1,在設備發生變化時不發送 uevent};
3.2 kobj_type
对象读写行为和释放逻辑
// /include/linux/kobject.hstruct kobj_type {void (*release)(struct kobject *kobj); // 对象销毁时的回调const struct sysfs_ops *sysfs_ops; // sysfs 文件读写方法struct attribute **default_attrs; // 默认属性文件列表
};
3.3 Kset
kset 是包含了多个 kobject 的集合,也就是说 kset 用来打包 kobject,例如现在我们需要在
/sys 目录下出创建多个目录或者文件,那么就需要使用 kset 来指定这些目录在同一级目录下。
// include/linux/kobject.h
struct kset {struct list_head list; // 所有屬於目前集合的 kobject 的鏈結串列spinlock_t list_lock; // 用於保護 liststruct kobject kobj; // kset 即為使用 kobject 的第一個例子,用於管理 kset 本身const struct kset_uevent_ops *uevent_ops; // function pointer,用於將集合的狀態資訊傳遞給 user space
};
3.4 Kref
kref 用来储存 kobject 的 reference count。
//include/linux/kref.h
struct kref {atomic_t refcount; // when o,release
};
3.5 树状图
3.6 文件操作
sysfs_buffer
/fs/sysfs/file.c
为了方便 user space 与 sysfs 交换数据,核心设计了 sysfs_buffer 这个资料结构。
open
/fs/sysfs/file.c
在open时,首先通过file取得kobject,指定ops为kobject内的ktype上的,检查写与 store、检查读与 show,没问题的话就分配一个 sysfs_buffer,最后将 file 指标中的 关连到 sysfs_buffer。sysfs_opsprivate_data
read
/fs/sysfs/file.c
若是在第一次读取或是写入后,就呼叫 show 函式来 refresh sysfs_buffer。 最后将sysfs_buffer 内的数据复制到参数传入的 buf。
write
/fs/sysfs/file.c
分配一个新的 page,再呼叫 store 函数。
4. 实验
4.1 关键点:
- 创建一个sysfs层次结构,包含多级子目录
- 添加一个可读写属性文件来控制整数值
- 当整数值被设为0时,动态删除一个子目录和符号链接
- 在模块卸载时正确清理sysfs条目
- 使用正确的引用计数管理kobject对象
// git 相关代码 Gist
#include <linux/device.h> // 设备相关函数和结构体
#include <linux/init.h> // 模块初始化宏
#include <linux/kernel.h> // 内核日志和类型定义
#include <linux/module.h> // 模块相关宏和函数
#include <linux/sysfs.h> // sysfs 相关函数和结构体// 模块静态变量
static int dev_int; // 将通过sysfs暴露的整数值
static struct device *dev; // 指向根设备的指针
static struct kobject *root, *s1, *s2, *s3; // sysfs层次结构中的kobject对象// sysfs属性的show函数
// 当读取属性时调用
static ssize_t dev1_show(struct device *dev, struct device_attribute *attr, char *buf) {return sprintf(buf, "dev_int: %d\n", dev_int); // 返回dev_int的当前值
}// sysfs属性的store函数
// 当写入属性时调用
static ssize_t dev1_store(struct device *dev, struct device_attribute *attr, const char *buf, size_t count) {sscanf(buf, "%d", &dev_int); // 解析输入并存储到dev_int// 当dev_int被设为0时的特殊行为if (dev_int == 0) {kobject_del(s3); // 删除subdir3的kobjectsysfs_remove_link(s2, "symlink_demo"); // 删除subdir2中的符号链接}return count; // 返回处理的字节数
}// 定义设备属性,包含show/store函数和权限(0660)
static struct device_attribute dev_attr = __ATTR(dev1, 0660, dev1_show, dev1_store);// 模块初始化函数
static int sysfs_demo_init(void) {printk(KERN_INFO "sysfs demo init\n");// 创建并注册根设备dev = root_device_register("sysfs_demo");root = &dev->kobj; // 获取根设备的kobject// 在sysfs中创建目录层次结构:// /sys/sysfs_demo/// /sys/sysfs_demo/subdir1/// /sys/sysfs_demo/subdir1/subdir2/// /sys/sysfs_demo/subdir1/subdir2/subdir3/s1 = kobject_create_and_add("subdir1", root); // 在root下创建subdir1s2 = kobject_create_and_add("subdir2", s1); // 在subdir1下创建subdir2s3 = kobject_create_and_add("subdir3", s2); // 在subdir2下创建subdir3// 在subdir2中创建属性文件sysfs_create_file(s2, &dev_attr.attr);// 在subdir2中创建指向subdir1的符号链接sysfs_create_link(s2, s1, "symlink_demo");return 0;
}// 模块清理函数
static void sysfs_demo_exit(void) {printk(KERN_INFO "sysfs demo exit\n");// 清理sysfs条目(按创建顺序的逆序)sysfs_remove_file(root, &dev_attr.attr); // 删除属性文件kobject_put(s2); // 递减s2的引用计数kobject_put(s1); // 递减s1的引用计数root_device_unregister(dev); // 注销根设备
}// 指定初始化和清理函数
module_init(sysfs_demo_init);
module_exit(sysfs_demo_exit);// 设置模块许可证(必需)
MODULE_LICENSE("GPL");
4.2 结果
这是一个 kernel module,一开始会建立一个名称为 dev1 的 device_attribute,传入的 function pointer,通过核心提供的 API作 kobject, 如果对 dev1 写入 0,会将 subdir2 下的符号连结与 subdir3 移除。
/sys/sysfs_demo/subdir1/subdir2/dev1 (属性文件)subdir3/symlink_demo (指向subdir1的符号链接)
4.3 创建实例
Task
- 创建makefile
- obj-m += simple.o
all: make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules clean:make -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean
- 创建simple.c
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/kobject.h>
#include <linux/sysfs.h>
#include <linux/string.h>// 定义 kset 和 kobject
static struct kset *my_kset;
static struct kobject *my_kobj;// sysfs 属性的值
static char my_value[100] = "default_value";// 读取 sysfs 属性
static ssize_t my_show(struct kobject *kobj, struct kobj_attribute *attr, char *buf)
{return sprintf(buf, "%s\n", my_value);
}// 写入 sysfs 属性
static ssize_t my_store(struct kobject *kobj, struct kobj_attribute *attr, const char *buf, size_t count)
{strncpy(my_value, buf, count);my_value[count - 1] = '\0'; // 确保字符串以 '\0' 结尾return count;
}// 定义一个 kobject 的属性
static struct kobj_attribute my_attribute = __ATTR(my_attr, 0664, my_show, my_store);// 初始化模块
static int __init my_module_init(void)
{int retval;// 创建 ksetmy_kset = kset_create_and_add("my_kset", NULL, kernel_kobj);if (!my_kset) {pr_err("Failed to create kset\n");return -ENOMEM;}// 创建 kobjectmy_kobj = kobject_create_and_add("my_kobj", &my_kset->kobj);if (!my_kobj) {pr_err("Failed to create kobject\n");kset_unregister(my_kset);return -ENOMEM;}// 创建 sysfs 属性retval = sysfs_create_file(my_kobj, &my_attribute.attr);if (retval) {pr_err("Failed to create sysfs file\n");kobject_put(my_kobj);kset_unregister(my_kset);return retval;}pr_info("Module loaded successfully\n");return 0;
}// 清理模块
static void __exit my_module_exit(void)
{// 删除 sysfs 属性sysfs_remove_file(my_kobj, &my_attribute.attr);// 释放 kobjectkobject_put(my_kobj);// 删除 ksetkset_unregister(my_kset);pr_info("Module unloaded successfully\n");
}module_init(my_module_init);
module_exit(my_module_exit);MODULE_LICENSE("GPL");
MODULE_AUTHOR("Your Name");
MODULE_DESCRIPTION("A simple kset/kobject sysfs example");
生成文件
tree
.
├── Makefile
├── modules.order
├── Module.symvers
├── simple.c
├── simple.ko
├── simple.mod
├── simple.mod.c
├── simple.mod.o
└── simple.o
// 装载 module
insmod simple.ko查看装载是否成功
lsmod | grep simple simple 16384 0
创建节点成功 生成了my_kset 节点
huangmang@ubuntu /s/k/my_kset> tree
.
└── my_kobj └── my_attr 1 directory, 1 file
参考资料
Linux Kernel v2.6.34 Source Code
Linux Kernel Development 3/e, Robert Love
Professional Linux Kernel Architecture, Wolfgang Mauerer
The sysfs Filesystem, Patrick Moch
udev – A Userspace Implementation of devfs, Greg Kroah-Hartman
https://blog.ykzheng.com/tech/sysfs/
相关文章:
sysfs 设备模型
介绍 Sysfs 设备文件系统与proc是同一类的文件系统,基于ramfs实现的内存文件系统。 1.1 为什么会有 sysfs?procfs 的局限性: 早期,Linux 使用 procfs 来提供内核与用户空间的交互接口。但 procfs 的设计不够层次化,设…...
彩讯携Rich AICloud与一体机智算解决方案亮相中国移动云智算大会
2025年4月10日,2025中国移动云智算大会在苏州盛大开幕,本次大会以“由云向智 共绘算网新生态”为主题,与会嘉宾围绕算力展开重点探讨。 大会现场特设区域展出各参会单位的最新算力成果,作为中国移动重要合作伙伴,彩讯…...
js触发隐式类型转换的场景
JavaScript 的隐式类型转换(Implicit Type Coercion)会在某些操作或上下文中自动触发,将值从一种类型转换为另一种类型。以下是常见的触发场景: 1. 使用 (宽松相等)比较时 会尝试将两边的值转换为相同类型后…...
《AI大模型应知应会100篇》第9篇:大模型的推理能力:原理与实现
第9篇:大模型的推理能力:原理与实现 摘要 近年来,随着大语言模型(LLM)的快速发展,其推理能力逐渐成为研究和应用中的热点话题。这些模型不仅能够生成流畅的文本,还能在一定程度上进行逻辑推理、…...
PODS_ROOT、BUILT_PRODUCTS_DIR和SRCROOT有什么区别
在 iOS/macOS 开发中,${PODS_ROOT}、${BUILT_PRODUCTS_DIR} 和 ${SRCROOT} 是三个核心的 Xcode 环境变量,它们的区别主要体现在 目录层级、内容归属 和 生命周期 上。以下是结构化对比和具体示例: 1. 定义与作用域对比 变量全称指向路径管理…...
Elasticsearch 系列专题 - 第六篇:高级功能与生态系统
Elasticsearch 不仅是一个强大的搜索引擎,还提供了高级功能和丰富的生态系统支持。本篇将深入探讨这些特性,并介绍如何与其他工具协同工作。 1. 高级特性 1.1 跨集群搜索(Cross-Cluster Search) 跨集群搜索允许查询多个独立集群的数据,适用于分布式系统。 配置远程集群:…...
python的web框架flask(hello,world版)
问题 最近需要基于一个开源项目进行二次开发,但是,现在的我主修java,从来没有接触过python的web开发。所以,我现在需要学习一下flask的hello,world。 python版本选择 通过这个Python版本状态页面Status of Python v…...
Vue学习笔记 - 逻辑复用 - 组合式函数
昨天参加了次视频面试,慢慢可以查漏补缺,继续学习Vue相关的知识,考虑找个实际的开源项目。 逻辑复用 组合式函数 在 Vue 应用的概念中,“组合式函数”(Composables) 是一个利用 Vue 的组合式 API 来封装和复用有状态逻辑的函数。 无状态的…...
Caffeine的两种实现方式
咱们来具体对比一下你之前给的这段配置代码👇: java Configuration EnableCaching public class CacheConfig { Bean public CacheManager cacheManager() { CaffeineCacheManager manager new CaffeineCacheManager("myCache"); manager.…...
单细胞Seurat标准分析流程R语言封装
单细胞Seurat标准分析流程R语言封装 数据预处理与质控(线粒体基因比例计算、QC图表生成)标准化与高变基因筛选PCA/UMAP降维与聚类分析 差异表达分析模块自动化输出PNG可视化图表(质控小提琴图、UMAP聚类图)结果将保存在results/和figures/目录下(RDS对象、差异基因CSV表格…...
MOS管的发热原因和解决办法
发热来源 如上图,MOS管的工作状态有4种情况,分别是开通过程,导通过程,关断过程和截止过程。 导致发热的损耗主要有两种:开关损耗、导通损耗。 导通损耗 导通损耗比较好计算,根据驱动电压VGS值可以得到MOS…...
航顺HK32M070电钻解决方案:驱动未来,掌控无限可能
一、市场规模与增长:电动工具行业持续扩容,电钻需求强劲 全球电动工具市场规模近年来保持稳定增长,2023年市场规模已达288.5亿美元,预计2024年将突破304.9亿美元,年复合增长率达6.9%。中国市场表现尤为亮眼࿰…...
关于nacos注册的服务的ip异常导致网关路由失败的问题
文章目录 关于nacos注册的服务的ip异常导致网关路由失败的问题相关处理方案为方案一:手动指定服务注册的 IP 地址方法二:设置优先使用的网络段方法三:指定网络接口方法四:忽略特定的网卡 备注 关于nacos注册的服务的ip异常导致网关路由失败的…...
UI测试流程与关键注意点解析
在当今以用户体验为核心的数字时代,用户界面(UI)作为软件与用户交互的直接窗口,其质量直接影响着产品的成败。UI测试作为软件测试的重要组成部分,确保应用程序不仅功能完善,而且在视觉呈现和交互体验上也能满足用户期望。 作为软…...
从零开始构建智能聊天机器人:Rasa与ChatGPT API实战教程
引言:AI对话系统的时代机遇 在数字化转型浪潮中,聊天机器人已成为连接用户与服务的关键纽带。无论是客服系统中的724小时即时响应,还是智能家居中的语音交互,聊天机器人正在重塑人机交互方式。本文将通过详细教程,手把…...
SSM aop切面编程的学习
面向切面的AOP编程的引入: 1. 代码缺陷 - 非核心代码对核心业务功能有干扰,导致程序员在开发核心业务功能时分散了精力 - 附加功能代码重复,分散在各个业务功能方法中!冗余,且不方便统一维护! 2. 解决思路 …...
Zen 5白色装机优选,华硕X870 AYW GAMING WIFI W主板来了!
华硕X870/X870E系列主板再次迎来新成员——华硕X870 AYW GAMING WIFI W主板正式发售!专为追求高性价比游戏玩家而量身打造,延续AYW系列经典SPACE太空元素,配合大面积银白色散热装甲,打造出了极具金属质感和科技感的外观࿰…...
第Y1周:调用YOLOv5官方权重进行检测
🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 文章目录 1、前言2、下载源码3、运行代码 1、前言 YOLOv5分为YOLOv5s、YOLOv5m、YOLOv5l、YOLOv5x四个版本,这里以YOLOv5s为例。 2、下载源码 安…...
科技项目验收测试怎么做?验收测试报告如何获取?
科技项目从研发到上市需要一个很长的周期,并且在上市之前还有一个至关重要的交付过程,那就是项目验收,验收需要通过验收测试来呈现。科技项目验收测试是确保项目成功交付的关键步骤,那么是如何进行的呢?企事业单位想要获取科技项…...
C++笔记
C知识笔记 一、C概述 C是一种通用编程语言,它在C语言的基础上扩展而来,支持面向对象编程、泛型编程和过程化编程等多种编程范式。C具有高效、灵活、接近硬件等特点,广泛应用于系统软件、应用软件、嵌入式系统、游戏开发等领域。其强大的性能…...
国产Linux统信安装mysql8教程步骤
系统环境 uname -a Linux FlencherHU-PC 6.12.9-amd64-desktop-rolling #23.01.01.18 SMP PREEMPT_DYNAMIC Fri Jan 10 18:29:31 CST 2025 x86_64 GNU/Linux下载离线安装包 浏览器下载https://downloads.mysql.com/archives/get/p/23/file/mysql-test-8.0.33-linux-glibc2.28…...
如何应对“最后时刻任务堆积”(鼓包现象)
应对“最后时刻任务堆积”(鼓包现象)的方法包括:合理规划项目时间表、强化进度跟踪管理、明确任务优先级、有效的资源配置、提升团队沟通效率。其中,强化进度跟踪管理尤为关键。根据项目管理协会(PMI)的调查…...
C语言,原码、补码、反码
计算机是以补码来存储的 原码:正数最高位为:0;负数最高位为:1 (最高位是符号位) 正数:三码合一 如:2: 原码:0000 0000 0000 0000 0000 0000 0000 0010&#…...
Unifying Short and Long-Term Tracking with Graph Hierarchies—CVPR2023
Unifying Short and Long-Term Tracking with Graph Hierarchies 博客目录 Unifying Short and Long-Term Tracking with Graph Hierarchies摘要概况引言和相关介绍提出的观点 SUSHI核心构建跟踪图的层次结构构建分层剪辑分区 做第二个创新模块的需要将研究的重点从处理遮挡的问…...
深入解析 C# 中的模板方法设计模式
模板方法设计模式(Template Method Pattern)是行为型设计模式中的一种,它定义了一个操作中的算法框架,并允许子类在不改变算法整体结构的情况下,重新定义该算法的某些步骤。该模式通常用于类中包含一系列固定步骤的算法…...
0411 | 软考高项笔记:项目立项
在软考的项目管理知识体系中,技术可行性和经济可行性是项目立项阶段非常重要的两个分析维度。以下是对这两个考点的详细解释和记忆方法: 技术可行性分析 定义: 技术可行性分析是评估项目在现有技术条件和资源下是否能够成功实施。它主要回答…...
ubnetu 服务器版本常用端口和开放的端口对应的应用
1. 使用 netstat 查看端口与进程 netstat 是查看网络连接和监听端口的常用工具。通过以下命令可以列出所有开放的TCP/UDP端口及其关联的进程: sudo netstat -tulnp参数解析: -t:显示TCP端口。 -u:显示UDP端口。 -l࿱…...
【服务器端表单字符验证】
文章目录 一、实验目的二、核心代码实现三、调试关键问题四、总结 一、实验目的 掌握JSP表单验证在服务器端的实现技术,实现对用户输入字符的非空及长度为5的验证,返回对应提示信息并优化用户交互。 二、核心代码实现 前端表单 <form action"…...
pip 与 conda 的全面比较:Python 包管理的深度解析
在 Python 的生态系统中,包管理工具是开发者日常工作的重要组成部分。其中,pip 和 conda 是最常用的两种包管理工具。虽然它们在功能上有一些重叠,但在设计理念、功能范围、依赖管理、环境隔离等方面存在显著差异。本文将从多个维度深入…...
GTID不一致修复
背景描述 GTID模式下,mysql主从切换后,主从同步报错 Last_IO_Error: Got fatal error 1236 from master when reading data from binary log: The slave is connecting using CHANGE MASTER TO MASTER_AUTO_POSITION 1, but the master has purged bi…...
conda-pack打包环境到超算上。解决无法打包可编辑包
conda-pack 打包 使用 conda-pack 打包 Conda 环境可以将整个环境打包成一个独立的可移植压缩包,方便在其他机器上解压使用。以下是具体步骤: 1.安装 conda-pack 首先需要安装 conda-pack。你可以通过 conda 或 pip 安装: conda install …...
O(n)复杂度实现寻找数组第k小的数(快速选择算法)
非堆排序实现,利用快速排序思想实现的快速选择 package algorithm;public class Test {public int quickSelect(int nums[], int left, int right, int k){if (left right) return nums[left];int i left - 1, j right 1, x nums[left];while (i < j){do i…...
利用 RNN 预测股票价格:从数据处理到可视化实战
在金融领域,预测股票价格走势一直是众多投资者和研究者关注的焦点。今天,我们将利用深度学习中的循环神经网络(RNN)来构建一个简单的股票价格预测模型,并详细介绍从数据加载、预处理、模型搭建、训练到最终结果可视化的…...
前端从全链路角度分析性能
在面试中回答“从全链路角度分析性能优化”时,需覆盖用户请求到页面渲染的完整链路。以下是结构化回答框架,结合业界实践和最新优化策略: 一、网络传输优化 1. CDN与协议升级 ◦ 使用CDN缩短资源物理距离,结合HTTP/2/3的多路复用和头部压缩特性,提升资源加载效率(如We…...
2025年第十八届“认证杯”数学中国数学建模网络挑战赛【BC题】完整版+代码+结果
# 问题一:随机森林回归from sklearn.ensemble import RandomForestRegressormodel_rf RandomForestRegressor()model_rf.fit(X_train, y_train)# 问题二:LSTM时间序列预测from tensorflow.keras.models import Sequentialmodel_lstm Sequential()model…...
权限管控与数据安全:衡石ChatBot在钉钉中的合规部署指南
数据安全是ChatBot落地的第一道门槛 在数字化转型浪潮下,企业数据查询正从“专业BI工具”向“自然语言交互”跃迁。衡石ChatBot通过钉钉等企业IM工具,让业务人员以对话方式实时获取数据,极大提升了决策效率。然而,数据开放的同时…...
什么是生产管理看板?
简单来说,生产管理看板就是一种把生产过程“摆在明面上”的工具——它可能是贴在墙上的白板,也可能是车间里一块大屏幕,主要作用就是让生产信息一目了然。 这种看板广泛用在工厂、制造车间、或者办公室里,它把生产计划、任务进度、库存情况、设备状态等重要数据通通“晒”…...
YOLO学习笔记 | 一文详解YOLOv11核心创新与实践方法
===================================================== github:https://github.com/MichaelBeechan CSDN:https://blog.csdn.net/u011344545 ===================================================== YOLOv11核心创新与实践 一、架构创新1. 模块升级与参数优化2. 多…...
198. 打家劫舍:动态规划
前言 本篇文章来自leedcode,是博主的学习算法的笔记心得。 如果觉得对你有帮助,可以点点关注,点点赞,谢谢你! 题目来源 198. 打家劫舍 - 力扣(LeetCode) 题目描述 思路 1.对于只有一个房间…...
算法基础模板
高精度加法 #include <bits/stdc.h> using namespace std; const int N10005; int A[N],B[N],C[N],al,bl,cl; void add(int A[],int B[],int C[]) {for(int icl-1;~i;i--){C[cl]A[i]B[i];C[cl1]C[cl]/10;C[cl]%10;}if(C[cl])cl; } int main() {string a,b;cin>>a&…...
【大模型LLM第十六篇】Agent学习之浅谈Agent loop的几种常见范式
anthropics agent https://zhuanlan.zhihu.com/p/32454721762 code:https://github.com/anthropics/anthropic-quickstarts/blob/main/computer-use-demo/computer_use_demo/loop.py sampling_loop函数 每次进行循环,输出extract tool_use࿰…...
[特殊字符] Spring Boot 日志系统入门博客大纲(适合初学者)
一、前言 📌 为什么日志在项目中如此重要? 在开发和维护一个后端系统时,日志就像程序运行时的“黑匣子”,帮我们记录系统的各种行为和异常。一份良好的日志,不仅能帮助我们快速定位问题,还能在以下场景中…...
【模拟电路】隧道二极管
与标准二极管相比,隧道二极管通过使用具有令人难以置信的大掺杂水平的半导体物质来工作,导致p-n结之间的耗尽层变得比最快的硅二极管窄约1000倍。 一旦隧道二极管正向偏置,整个p-n结开始发生称为电子流“隧穿”的过程。 在测试隧道二极管的…...
qwen-vl 实现OCR的测试
OCR 技术是数字化时代必不可少的实用工具。以前都依赖专业的公司的专业软件才能完成。成本很高。也正因为如此,我国纸质资料的数字化并不普及。基于大模型的ORC 也许会改变这样的现状。 文本识别,也称为光学字符识别 (OCR),可以将印刷文本或…...
3.0/Q2,Charls最新文章解读
文章题目:Exploring the association between socioeconomic inequalities in chronic respiratory disease and all-cause mortality in China: findings from the China Health and Retirement Longitudinal Study DOI:10.3389/fpubh.2024.1472074 中文…...
【大模型系列篇】基于Ollama和GraphRAG v2.0.0快速构建知识图谱
GraphRAG是一种结合了知识图谱和大型语言模型的检索增强生成(RAG)技术。它通过引入图结构化的知识表示和处理方法,显著提升了传统RAG系统的能力,为处理复杂和多样化数据提供了强有力的支持。更多介绍可以跳转《最强检索增强技术Gr…...
Wincc管对象的使用
Wincc管对象的使用 管对象的调用多边形管T形管双T形管管弯头管道大小调整 管对象的调用 打开【图形编辑器】 多边形管 多边形管如下: 一根管子的顶点数是两个,如果修改顶点数,管子就有多少个端点。 修改顶点数为5 此时点击端点然后拖动&#…...
springboot--页面的国际化
今天来实现页面中的国际化 首先,需要创建一个新的spring boot项目,导入前端模板,在我的博客中可以找到,然后将HTML文件放在templates包下,将其他的静态资源放在statics包下,如下图结构 页面的国际化主要在首…...
记 etcd 无法在docker-compose.yml启动后无法映射数据库目录的问题
1、将etcd 单独提取 Dockerfile #镜像 FROM bitnami/etcd:3.5.11 #名称 ENV name"etcd" #重启 ENV restart"always" #运行无权限 ENV ALLOW_NONE_AUTHENTICATION"yes" #端口 EXPOSE 2379 2380 #管理员权限才能创建数据库 USER root # 设置入口点…...
c++关键字new
链接:【C】C中的new关键字用法详解...