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

从相似推荐到异常检测:手把手用PyTorch实现余弦相似度与欧氏距离的实战项目

从相似推荐到异常检测手把手用PyTorch实现余弦相似度与欧氏距离的实战项目在推荐系统和异常检测领域相似度计算是最基础也最核心的技术之一。想象一下当你在电商平台浏览商品时系统如何精准推荐你可能喜欢的其他商品当工厂的传感器采集到海量数据时又如何快速识别出异常设备状态这些场景背后都离不开相似度算法的支撑。PyTorch作为当前最流行的深度学习框架之一提供了丰富的张量操作和距离计算函数。本文将带你用PyTorch实现两个完整的实战项目一个基于余弦相似度的简易推荐系统和一个基于欧氏距离的异常检测系统。我们不仅会讲解API的使用更会聚焦于如何将这些数学概念转化为实际可用的解决方案。1. 环境准备与数据构建在开始项目之前我们需要准备好开发环境。推荐使用Python 3.8和PyTorch 1.10版本这些版本提供了最稳定的API支持。pip install torch torchvision numpy matplotlib1.1 构建电影推荐数据集为了演示推荐系统我们将创建一个模拟的电影评分数据集。这个数据集包含10个用户对20部电影的评分评分范围1-5分。import torch import numpy as np # 设置随机种子保证可重复性 torch.manual_seed(42) # 生成用户-电影评分矩阵 (10用户 × 20电影) num_users 10 num_movies 20 ratings torch.randint(1, 6, (num_users, num_movies)).float() # 添加一些缺失值(未评分) mask torch.rand(num_users, num_movies) 0.7 ratings[mask] 0 # 0表示未评分 print(f评分矩阵形状: {ratings.shape}) print(ratings[:3, :5]) # 展示前3个用户对前5部电影的评分1.2 准备异常检测数据对于异常检测项目我们将生成包含正常点和异常点的二维数据。正常点来自一个高斯分布异常点则是随机分布的离群点。# 生成正常数据点 normal_data torch.randn(100, 2) * 0.5 torch.tensor([2.0, 2.0]) # 生成异常数据点 anomaly_data torch.rand(20, 2) * 6 - 3 # 范围在[-3,3] # 合并数据集 all_data torch.cat([normal_data, anomaly_data], dim0) labels torch.cat([torch.zeros(100), torch.ones(20)]) # 0正常,1异常 # 可视化数据 import matplotlib.pyplot as plt plt.scatter(normal_data[:,0], normal_data[:,1], label正常) plt.scatter(anomaly_data[:,0], anomaly_data[:,1], colorr, label异常) plt.legend() plt.title(异常检测数据集) plt.show()2. 基于余弦相似度的推荐系统实现余弦相似度衡量的是两个向量在方向上的相似程度而不考虑它们的大小。这在推荐系统中特别有用因为我们更关注用户的偏好模式而非评分绝对值。2.1 计算用户相似度首先我们实现一个基于用户的协同过滤算法找到相似用户进行推荐。from torch.nn.functional import cosine_similarity def user_based_cf(ratings, user_idx, top_k3): 基于用户的协同过滤推荐 :param ratings: 用户-电影评分矩阵 :param user_idx: 目标用户索引 :param top_k: 返回最相似的k个用户 :return: 推荐电影列表 # 计算目标用户与其他用户的相似度 target ratings[user_idx].unsqueeze(0) # 形状变为(1, num_movies) sims cosine_similarity(target, ratings, dim1) # 排除用户自己 sims[user_idx] -1 # 获取最相似的top_k用户 _, similar_users torch.topk(sims, top_k) # 找出这些相似用户喜欢但目标用户未评分的电影 similar_users_ratings ratings[similar_users] avg_ratings similar_users_ratings.mean(dim0) # 目标用户未评分的电影 unrated (ratings[user_idx] 0) # 推荐评分最高的未看电影 recommended torch.argsort(avg_ratings * unrated, descendingTrue) return recommended[:5] # 返回前5个推荐 # 测试推荐系统 user_idx 0 recommendations user_based_cf(ratings, user_idx) print(f为用户{user_idx}推荐的电影索引: {recommendations})2.2 实现物品相似度推荐除了基于用户的推荐我们还可以计算电影之间的相似度实现基于物品的推荐。def item_based_cf(ratings, user_idx, top_k5): 基于物品的协同过滤推荐 :param ratings: 用户-电影评分矩阵 :param user_idx: 目标用户索引 :param top_k: 对每个已评分电影考虑最相似的k个电影 :return: 推荐电影列表 # 转置矩阵得到电影-用户矩阵 movie_user ratings.T # 计算电影之间的相似度矩阵 num_movies movie_user.shape[0] movie_sim torch.zeros(num_movies, num_movies) for i in range(num_movies): for j in range(i, num_movies): # 只计算都评过分的用户 mask (movie_user[i] 0) (movie_user[j] 0) if mask.sum() 0: sim cosine_similarity(movie_user[i][mask].unsqueeze(0), movie_user[j][mask].unsqueeze(0)) movie_sim[i,j] movie_sim[j,i] sim.item() # 获取目标用户已评分的电影 rated_movies torch.where(ratings[user_idx] 0)[0] # 计算推荐得分 scores torch.zeros(num_movies) for movie in rated_movies: # 获取当前电影的top_k相似电影 _, similar_movies torch.topk(movie_sim[movie], top_k) # 累加相似度作为推荐分数 for sim_movie in similar_movies: if ratings[user_idx, sim_movie] 0: # 只考虑未评分的 scores[sim_movie] movie_sim[movie, sim_movie] # 推荐得分最高的电影 recommended torch.argsort(scores, descendingTrue) return recommended[:5] # 测试物品相似度推荐 recommendations item_based_cf(ratings, user_idx) print(f基于物品相似度为用户{user_idx}推荐的电影: {recommendations})2.3 推荐系统评估为了评估推荐系统的效果我们可以使用留出法计算预测评分与实际评分的差异。def evaluate_recommendation(ratings, user_idx, k5): 评估推荐系统效果 :param ratings: 完整评分矩阵 :param user_idx: 目标用户索引 :param k: 隐藏k个评分作为测试集 :return: 预测评分与实际评分的平均绝对误差 # 复制评分矩阵并隐藏k个评分 test_ratings ratings.clone() rated torch.where(ratings[user_idx] 0)[0] test_indices torch.randperm(len(rated))[:k] hidden_ratings ratings[user_idx, rated[test_indices]] test_ratings[user_idx, rated[test_indices]] 0 # 获取推荐 recommended user_based_cf(test_ratings, user_idx, top_k3) # 计算预测评分(使用相似用户的平均评分) target test_ratings[user_idx].unsqueeze(0) sims cosine_similarity(target, test_ratings, dim1) sims[user_idx] -1 _, similar_users torch.topk(sims, 3) # 计算预测评分 pred_ratings test_ratings[similar_users][:, rated[test_indices]].mean(dim0) # 计算MAE mae torch.abs(pred_ratings - hidden_ratings).mean() return mae.item() # 评估推荐系统 mae evaluate_recommendation(ratings, user_idx) print(f推荐系统MAE: {mae:.2f})3. 基于欧氏距离的异常检测系统欧氏距离衡量的是空间中两点之间的直线距离非常适合用于检测偏离正常模式的异常点。3.1 计算欧氏距离PyTorch提供了多种计算欧氏距离的方法我们来比较它们的性能和使用场景。from torch.nn import PairwiseDistance from torch.cdist import cdist # 定义三个计算欧氏距离的方法 def euclidean_dist1(a, b): 使用PairwiseDistance pdist PairwiseDistance(p2) return pdist(a.unsqueeze(0), b.unsqueeze(0)) def euclidean_dist2(a, b): 使用vector_norm return torch.linalg.vector_norm(a - b, ord2) def euclidean_dist3(a, b): 使用cdist return cdist(a.unsqueeze(0), b.unsqueeze(0), p2) # 测试三种方法 a torch.tensor([1.0, 2.0]) b torch.tensor([4.0, 6.0]) print(fPairwiseDistance: {euclidean_dist1(a, b).item():.4f}) print(fvector_norm: {euclidean_dist2(a, b).item():.4f}) print(fcdist: {euclidean_dist3(a, b).item():.4f})3.2 实现简单异常检测器我们将使用欧氏距离来实现一个基于密度的异常检测算法。def density_based_anomaly_detection(data, k5, threshold0.9): 基于密度的异常检测 :param data: 输入数据 (n_samples, n_features) :param k: 考虑的最近邻数量 :param threshold: 异常分数阈值 :return: 异常分数和预测标签 # 计算所有点之间的距离矩阵 dist_matrix cdist(data, data, p2) # 对每个点获取到k个最近邻的距离 topk_dists, _ torch.topk(dist_matrix, k1, largestFalse) # 1因为包含自己 avg_knn_dist topk_dists[:, 1:].mean(dim1) # 排除自身 # 计算异常分数 (标准化到0-1) anomaly_scores (avg_knn_dist - avg_knn_dist.min()) / (avg_knn_dist.max() - avg_knn_dist.min()) # 预测异常 pred_labels (anomaly_scores threshold).long() return anomaly_scores, pred_labels # 运行异常检测 anomaly_scores, pred_labels density_based_anomaly_detection(all_data) # 可视化结果 plt.scatter(all_data[:,0], all_data[:,1], cpred_labels, cmapcoolwarm) plt.title(异常检测结果(红色异常)) plt.show()3.3 评估异常检测性能我们可以计算准确率、召回率等指标来评估异常检测器的性能。def evaluate_anomaly_detection(true_labels, pred_labels): 评估异常检测性能 :param true_labels: 真实标签 (0正常,1异常) :param pred_labels: 预测标签 (0正常,1异常) :return: 准确率,召回率,F1分数 # 计算混淆矩阵 tp ((true_labels 1) (pred_labels 1)).sum().item() fp ((true_labels 0) (pred_labels 1)).sum().item() fn ((true_labels 1) (pred_labels 0)).sum().item() tn ((true_labels 0) (pred_labels 0)).sum().item() # 计算指标 accuracy (tp tn) / (tp fp fn tn) precision tp / (tp fp) if (tp fp) 0 else 0 recall tp / (tp fn) if (tp fn) 0 else 0 f1 2 * (precision * recall) / (precision recall) if (precision recall) 0 else 0 return accuracy, precision, recall, f1 # 评估性能 accuracy, precision, recall, f1 evaluate_anomaly_detection(labels, pred_labels) print(f准确率: {accuracy:.2f}, 精确率: {precision:.2f}, 召回率: {recall:.2f}, F1分数: {f1:.2f})4. 高级应用与性能优化在实际应用中我们需要考虑算法的扩展性和性能优化特别是当数据量很大时。4.1 批量计算与GPU加速PyTorch的一个主要优势是可以利用GPU进行并行计算。我们来看如何优化距离计算。def batch_cosine_similarity(queries, targets, batch_size64, devicecuda): 分批计算余弦相似度以避免内存不足 :param queries: 查询向量 (n_queries, dim) :param targets: 目标向量 (n_targets, dim) :param batch_size: 每批大小 :param device: 计算设备 :return: 相似度矩阵 (n_queries, n_targets) queries queries.to(device) targets targets.to(device) n_queries queries.shape[0] sim_matrix torch.zeros(n_queries, targets.shape[0], devicedevice) for i in range(0, n_queries, batch_size): batch queries[i:ibatch_size] # 计算当前batch与所有目标的相似度 sim_batch cosine_similarity(batch.unsqueeze(1), targets.unsqueeze(0), dim2) sim_matrix[i:ibatch_size] sim_batch return sim_matrix.cpu() # 测试批量计算 large_ratings torch.randn(1000, 100) # 1000用户×100电影 sim_matrix batch_cosine_similarity(large_ratings[:100], large_ratings) print(f批量相似度矩阵形状: {sim_matrix.shape})4.2 近似最近邻搜索当数据量非常大时精确计算所有点对的距离变得不可行。我们可以使用近似最近邻算法来提高效率。def approximate_knn(query, data, k10, n_probes5, hash_size8): 使用局部敏感哈希(LSH)进行近似最近邻搜索 :param query: 查询向量 :param data: 数据集 :param k: 返回的最近邻数量 :param n_probes: 探测的哈希桶数量 :param hash_size: 哈希位数 :return: 最近邻的索引和距离 dim data.shape[1] # 生成随机投影向量 projection torch.randn(dim, hash_size, devicedata.device) # 计算哈希签名 signatures torch.sign(data projection) # 将二进制签名转换为整数哈希值 powers torch.arange(hash_size-1, -1, -1, devicedata.device) powers 2 ** powers hash_values (signatures 0).int() powers.unsqueeze(1) # 查询的哈希值 query_sig torch.sign(query projection) query_hash ((query_sig 0).int() powers).item() # 找到相同哈希桶中的候选点 candidates torch.where(hash_values query_hash)[0] # 如果没有足够候选点扩大搜索范围 if len(candidates) n_probes: # 查找哈希值相近的桶 all_hashes hash_values.unique() hash_diff (all_hashes ^ query_hash).abs() closest_hashes all_hashes[torch.topk(hash_diff, n_probes, largestFalse).indices] for h in closest_hashes: candidates torch.cat([candidates, torch.where(hash_values h)[0]]) # 计算候选点的实际距离 if len(candidates) 0: dists torch.cdist(query.unsqueeze(0), data[candidates], p2).squeeze(0) topk_indices torch.topk(dists, min(k, len(dists)), largestFalse).indices return candidates[topk_indices], dists[topk_indices] else: return torch.tensor([]), torch.tensor([]) # 测试近似最近邻 query torch.randn(100) data torch.randn(10000, 100) indices, dists approximate_knn(query, data) print(f找到的最近邻索引: {indices[:5]}, 距离: {dists[:5]})4.3 混合推荐系统结合用户相似度和物品相似度可以构建更强大的混合推荐系统。class HybridRecommender: def __init__(self, ratings, user_weight0.5): self.ratings ratings self.user_weight user_weight # 用户相似度的权重 self.item_weight 1 - user_weight # 物品相似度的权重 # 预计算物品相似度矩阵 self.item_sim self._compute_item_similarity() def _compute_item_similarity(self): 计算物品相似度矩阵 item_user self.ratings.T num_items item_user.shape[0] item_sim torch.zeros(num_items, num_items) for i in range(num_items): for j in range(i, num_items): mask (item_user[i] 0) (item_user[j] 0) if mask.sum() 0: sim cosine_similarity(item_user[i][mask].unsqueeze(0), item_user[j][mask].unsqueeze(0)) item_sim[i,j] item_sim[j,i] sim.item() return item_sim def recommend(self, user_idx, top_k5): 生成混合推荐 # 用户相似度推荐得分 target self.ratings[user_idx].unsqueeze(0) user_sims cosine_similarity(target, self.ratings, dim1) user_sims[user_idx] -1 # 排除自己 _, similar_users torch.topk(user_sims, 3) user_based_scores self.ratings[similar_users].mean(dim0) # 物品相似度推荐得分 rated_movies torch.where(self.ratings[user_idx] 0)[0] item_based_scores torch.zeros(self.ratings.shape[1]) for movie in rated_movies: _, similar_movies torch.topk(self.item_sim[movie], 3) for sim_movie in similar_movies: if self.ratings[user_idx, sim_movie] 0: item_based_scores[sim_movie] self.item_sim[movie, sim_movie] # 合并得分 combined_scores (self.user_weight * user_based_scores self.item_weight * item_based_scores) # 只推荐未评分的 unrated (self.ratings[user_idx] 0) recommended torch.argsort(combined_scores * unrated, descendingTrue) return recommended[:top_k] # 测试混合推荐 hybrid_rec HybridRecommender(ratings, user_weight0.7) recommendations hybrid_rec.recommend(user_idx) print(f混合推荐结果: {recommendations})

相关文章:

从相似推荐到异常检测:手把手用PyTorch实现余弦相似度与欧氏距离的实战项目

从相似推荐到异常检测:手把手用PyTorch实现余弦相似度与欧氏距离的实战项目 在推荐系统和异常检测领域,相似度计算是最基础也最核心的技术之一。想象一下,当你在电商平台浏览商品时,系统如何精准推荐你可能喜欢的其他商品&#xf…...

CentOS 7实战:从零到一构建ClickHouse高性能分析平台

1. 为什么选择ClickHouse构建分析平台 如果你正在寻找一个能够快速处理海量数据的分析型数据库,ClickHouse绝对值得考虑。这个由俄罗斯Yandex公司开源的列式存储数据库,在处理OLAP(在线分析处理)场景时表现出色。我曾在多个项目中…...

告别RTKlib!我用Matlab APP Designer手搓了一个GNSS数据质量分析工具(附源码)

告别RTKlib!我用Matlab APP Designer手搓了一个GNSS数据质量分析工具(附源码) 去年夏天在湖边做GNSS静态测量时,突然发现RTKlib输出的多路径误差曲线出现异常波动。为了确认是软件问题还是真实信号干扰,我不得不手动导…...

PyTorch张量并行技术解析与实战指南

1. 理解张量并行技术在训练超大规模Transformer模型时,单张GPU的内存容量往往成为瓶颈。张量并行(Tensor Parallelism)是一种模型并行技术,它通过将单个张量沿特定维度切分,将计算任务分配到多个设备上执行。这种技术最…...

PageAdmin平台化:多业务系统动态构建技术

以下是针对“PageAdmin应用系统平台化”的技术实现方案,聚焦于将传统单应用后台管理系统改造为可无限创建业务系统的低代码平台,仅涉及技术架构与实现步骤。 一、平台化核心架构设计 将PageAdmin从“单个后台系统”改造为多业务系统托管平台&#xff0c…...

Neeshck-Z-lmage_LYX_v2行业落地:医疗科普插图AI辅助生成合规性实践

Neeshck-Z-lmage_LYX_v2行业落地:医疗科普插图AI辅助生成合规性实践 1. 引言:当AI绘画遇上医疗科普 想象一下,一位医学编辑正在为一篇关于“心脏瓣膜工作原理”的科普文章寻找配图。他需要的不是一张冰冷的医学解剖图,而是一张既…...

AI项目实战开发

Python 爬虫 AI 总结:自动生成行业日报系统 引言 摘要:本节给出关键结论、核心步骤和可执行建议。 对很多工程团队来说,“行业日报”并不是内容运营问题,而是一个典型的信息工程问题:多源采集、增量更新、内容清洗、…...

real-anime-z多场景落地:儿童绘本插画、教育课件配图、科普信息图风格生成

real-anime-z多场景落地:儿童绘本插画、教育课件配图、科普信息图风格生成 1. 模型介绍与部署 real-anime-z是基于Z-Image的LoRA版本模型,专注于生成真实风格的动画图片。该模型特别适合需要高质量动漫风格图像的各类应用场景。 使用Xinference部署re…...

malloc/free时代终结?2026规范强制引入bounded_alloc与lifetime-aware API——7类传统代码模式已成高危禁区(附自动化检测脚本)

第一章:现代 C 语言内存安全编码规范 2026 对比评测报告随着 CVE-2023–29357 等高危堆溢出漏洞持续暴露传统 C 项目风险,ISO/IEC JTC1 SC22 WG14 于 2025 年底正式发布《C Memory Safety Profile 2026》(CMS-2026),作…...

超越官方限制:在Leaflet中实现天地图无级缩放与高清瓦片叠加显示

突破Leaflet与天地图的无级缩放边界:高清瓦片叠加与性能优化实战 当我们在开发基于Leaflet的地理信息系统时,经常会遇到一个令人困扰的限制——天地图官方瓦片服务的最大缩放级别通常被锁定在17或18级。但对于某些专业应用场景,比如城市规划、…...

全志D1s/F133 RISC-V处理器架构与应用解析

1. Allwinner D1s/F133 RISC-V处理器深度解析全志科技最新推出的D1s(又称F133)处理器,作为D1 RISC-V处理器的精简版本,在保持核心功能的同时通过集成64MB DDR2内存显著降低了成本。这款处理器主要面向智能摄像头和显示屏市场&…...

从CT设备数据流中断到容器网络修复,Docker医疗调试黄金6小时响应流程全披露

第一章:从CT设备数据流中断到容器网络修复,Docker医疗调试黄金6小时响应流程全披露当医院影像科CT设备突然停止向PACS系统推送DICOM影像,后台日志显示“connection refused to 10.244.3.17:4242”,而该IP正是运行DICOM网关服务的D…...

Stata实战:用5种方法搞定分组回归系数差异检验(附完整代码与避坑指南)

Stata分组回归系数差异检验:5种方法的深度实操与选择逻辑 当研究国有企业与非国有企业的薪酬激励效果差异时,分组回归系数检验是绕不开的实证关卡。但面对reghdfe高维固定效应下的报错警告、结果不显著或方法选择困惑,许多研究者往往陷入技术…...

lvgl_v8之自定义图片解码回调函数代码示例(亲测好用)

#pragma pack(1)// BMP 文件头结构体(14字节) typedef struct {...

logo抠图背景去不掉?PS 4种方法一键搞定

抠图是设计师必备的基础技能,但很多新手在处理logo抠图时,总会遇到各种问题:复杂背景的logo抠半天,边缘留灰边、丢失细节;面对PS众多工具,无从下手、反复试错。今天就给大家分享3种PS logo抠图去背景的实用…...

基于UDS的BootLoader上位机源代码(C#):支持ISO通信与多种CAN卡,S-rec...

基于UDS的BootLoader上位机源代码(C#) 基于UDS的BootLoader上位机源代码,支持ISO15765通信,支持PeakCAN , ZJG CAN等CAN卡, 支持S-record格式的二进制文件解析; 可二次开发或扩展应用。一、概述 本文档详细解读基于UDS…...

用MSP430和Cyclone IV FPGA实现单相逆变电源的PID闭环控制(附完整代码)

MSP430FPGA架构下的单相逆变电源PID闭环控制实战解析 在电力电子控制领域,实现高精度电压输出一直是工程师面临的挑战。当MSP430微控制器遇上Cyclone IV FPGA,这种混合架构为单相逆变电源的控制带来了独特优势——MCU负责复杂算法运算,FPGA专…...

告别VMware启动卡顿:深入解析“请移除安装介质”的根源与自动化修复

1. 为什么VMware会提示"请移除安装介质"? 这个问题本质上是个"假警报"。虚拟机启动时,固件(BIOS/UEFI)会按照预设的启动顺序逐个检测设备。当它发现某个被标记为"可启动"的安装介质(ISO…...

用Python爬虫+GPT-4分析肯尼迪演说词频:一次文本挖掘与历史语料处理的实战

用Python解析肯尼迪演说:从词频统计到AI深度解读的技术实践 1961年那个寒冷的1月早晨,约翰F肯尼迪站在国会大厦台阶上发表的演说,至今仍被视为20世纪最具影响力的政治演讲之一。作为技术从业者,我们如何用现代工具来解析这份历史文…...

【限时开源】我们刚在千万级订单系统落地的Docker日志瘦身框架(已压缩日志量至原体积6.8%,GitHub Star 423+,仅开放前100名下载)

第一章:Docker日志优化的行业痛点与落地价值在微服务与云原生大规模落地的今天,Docker容器日志已成为可观测性体系中最基础却最易被忽视的一环。大量企业面临日志爆炸式增长、磁盘空间不可控、检索效率低下、多容器日志混杂难溯源等共性挑战,…...

万象视界灵坛代码实例:Python调用Omni-Vision Sanctuary API实现批量图像语义评分

万象视界灵坛代码实例:Python调用Omni-Vision Sanctuary API实现批量图像语义评分 1. 平台概览与技术背景 万象视界灵坛(Omni-Vision Sanctuary)是一款基于OpenAI CLIP模型的高级多模态智能感知平台。它通过创新的像素风格界面,…...

【限时开源】我司金融级Docker沙箱基线镜像(已通过CNCF Sig-Auth认证,仅开放72小时下载)

第一章:Docker沙箱的核心价值与金融级安全边界在金融行业,容器化运行环境不仅需满足常规隔离性要求,更须承载交易系统、风控引擎与客户数据处理等高敏场景的强合规约束。Docker沙箱通过内核命名空间(Namespaces)、控制…...

BililiveRecorder录播引擎深度解析:3大核心架构与5项企业级部署策略

BililiveRecorder录播引擎深度解析:3大核心架构与5项企业级部署策略 【免费下载链接】BililiveRecorder 录播姬 | mikufans 生放送录制 项目地址: https://gitcode.com/gh_mirrors/bi/BililiveRecorder BililiveRecorder作为一款专注于B站直播录制的开源工具…...

NVISEN FU01无风扇迷你主机评测与配置指南

1. NVISEN FU01 无风扇迷你主机深度解析这款搭载英特尔Tiger Lake处理器的无风扇迷你电脑,完美诠释了"小而强大"的设计理念。作为一款主打静音和高效能的迷你主机,NVISEN FU01特别适合需要安静工作环境的用户,比如录音室、医疗影像…...

从BD4954到PMOS管:拆解一个真实物联网产品的太阳能充电管理电路,附完整PCB布局建议

从BD4954到PMOS管:拆解一个真实物联网产品的太阳能充电管理电路,附完整PCB布局建议 在低功耗物联网设备的设计中,电源管理系统的可靠性往往决定了产品的成败。我曾参与开发一款户外环境监测终端,设备需要在零下20℃至60℃的温度范…...

别再只用水平IoU了!手把手教你用OpenCV计算旋转目标检测框的重叠度(附Python代码)

突破水平检测局限:OpenCV旋转框IoU计算实战指南 在遥感图像分析、自动驾驶感知和文档识别等场景中,目标物体往往呈现任意角度的旋转状态。传统水平检测框的IoU计算方法在这些场景下会严重高估检测质量——比如两个完全错位的长条形物体,仅因外…...

PPTXjs:零安装!在浏览器中完美预览PPTX文件的终极方案

PPTXjs:零安装!在浏览器中完美预览PPTX文件的终极方案 【免费下载链接】PPTXjs jquery plugin for convertation pptx to html 项目地址: https://gitcode.com/gh_mirrors/pp/PPTXjs 还在为无法在线查看PPTX文件而烦恼吗?PPTXjs为你带…...

TwitchDropsMiner:解放双手,轻松获取游戏奖励的智能助手

TwitchDropsMiner:解放双手,轻松获取游戏奖励的智能助手 【免费下载链接】TwitchDropsMiner An app that allows you to AFK mine timed Twitch drops, with automatic drop claiming and channel switching. 项目地址: https://gitcode.com/GitHub_Tr…...

告别VM软件界面!用C#给VisionMaster 4.2 SDK做个专属上位机(附完整源码)

用C#打造VisionMaster 4.2工业视觉定制化上位机实战指南 在工业自动化领域,标准化的视觉处理软件往往难以完全匹配特定产线的操作流程和界面需求。VisionMaster作为业内知名的机器视觉算法平台,其SDK为开发者提供了强大的二次开发能力。本文将带您从零开…...

告别蜗牛速度:3步教你用BaiduPCS-Web实现百度网盘全速下载

告别蜗牛速度:3步教你用BaiduPCS-Web实现百度网盘全速下载 【免费下载链接】baidupcs-web 项目地址: https://gitcode.com/gh_mirrors/ba/baidupcs-web 还在为百度网盘几十KB/s的下载速度而烦恼吗?BaiduPCS-Web是一款基于Go语言开发的开源百度网…...