np.clip的使用

news/2025/9/19 17:30:12/文章来源:https://www.cnblogs.com/lidadudu/p/19101347

np.clip() 是 NumPy 中一个非常实用的函数,用于将数组中的值裁剪(或者说限制)在一个指定的区间内。

它的作用就像一把剪刀,把数组中所有超出规定范围的数值都剪掉,让它们回到这个范围的边缘。

np.clip() 的基本用法

np.clip() 的基本语法是:
np.clip(a, a_min, a_max, out=None)

  • a: 你想要裁剪的数组(或数值)。
  • a_min: 数组中数值的下限。所有小于 a_min 的值都会被替换成 a_min
  • a_max: 数组中数值的上限。所有大于 a_max 的值都会被替换成 a_max

示例

假设你有一个数组,你想让它的所有值都在 0 到 10 之间。

import numpy as np# 创建一个包含各种数值的数组
arr = np.array([-5, 2, 8, 12, 100, 0.5])# 将数组中的值限制在 [0, 10] 范围内
clipped_arr = np.clip(arr, 0, 10)print(clipped_arr)
# 输出: [ 0.  2.  8. 10. 10.  0.5]

可以看到,在这个例子中:

  • -5 小于下限 0,所以被裁剪成了 0
  • 12100 都大于上限 10,所以都被裁剪成了 10
  • 2, 8, 0.5 都在 010 之间,所以它们的值保持不变。

np.clip() 在机器学习中的应用

np.clip() 在机器学习中非常有用,通常用于防止数值溢出确保结果的稳定性。在你的代码中,它有两个关键的应用:

  1. 在 Softmax 函数内部防止上溢

def softmax(x):
x = np.clip(x,-1e10,100)
ex = np.exp(x)
sum_ex = np.sum(ex,axis=1,keepdims=True)

result = ex/sum_exresult = np.clip(result,1e-10,1e10)
return  result
```Softmax 函数会使用 `np.exp()` 进行指数运算。如果 `x` 的值太大(例如超过709),`np.exp(x)` 会发生**上溢**,结果变为 `inf`(无穷大)。`np.clip()` 将 `x` 的值限制在 100,确保 `np.exp()` 的结果在一个可计算的范围内,从而避免了溢出。
  1. 在 Softmax 函数输出后防止对数运算错误

    result = np.clip(result, 1e-10, 1e10)
    loss = -np.mean(batch_labels * np.log(result))
    

    交叉熵损失函数使用了 np.log()。如果 Softmax 的输出 result 中有任何一个值是 0np.log(0) 的结果将是 -inf,导致整个程序崩溃。通过将 result 的值限制在一个非常小的正数(1e-10)以上,np.clip() 确保了 np.log() 的输入永远不会是0,从而提高了程序的稳定性
    不过这样做有点太蠢了,建议X直接减去最大值,至于证明的话,可以搜一下。

def stable_softmax(x):z = x - np.max(x, axis=1, keepdims=True) # 减去每行的最大值ex = np.exp(z)return ex / np.sum(ex, axis=1, keepdims=True)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/907957.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

重看P4211 [LNOI2014] LCA 以及 P5305 [GXOI/GZOI2019] 旧词 题解

P4211 [LNOI2014] LCA P5305 [GXOI/GZOI2019] 旧词 重看 P4211 求 \(\sum_{i=l}^{r} dep[LCA(i,x)]\),首先把 LCA 都求出来行不通,我们考虑转化计算贡献的形式,一个点的深度就是根到它的路径上的点的个数,两个点的…

25.9.19随笔联考总结

考试 通读题面,决定顺序开题。很快做出 T1,感觉 T2T3 都可做,优势在我!各想一个小时未果,T4 也不会,坠机。赛后得知后三道都是 NOI 难度的题。 估计:100+0+0+0。实际:100+0+0+0。 总结 面对一些神秘题的时候还…

解题报告-P12025 [USACO25OPEN] Sequence Construction S

P12025 [USACO25OPEN] Sequence Construction S 题目描述 最近,农夫约翰农场里的奶牛们迷上了观看《炼乳神探》这档节目。节目讲述了一头聪明的奶牛侦探CowCow解决各类案件的故事。贝茜从节目中发现了新的谜题,但答案…

解题报告-P12026 [USACO25OPEN] Compatible Pairs S

P12026 [USACO25OPEN] Compatible Pairs S 题目描述 在遥远的乡村,农夫约翰的奶牛并非普通的农场动物——它们隶属于一个秘密的奶牛情报网络。每头奶牛都有一个由精英密码学家精心分配的ID号码。但由于农夫约翰随意的…

深入解析:Xilinx Video Mixer

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

maxu

https://v1.paoliangcloud.com/publicwowo.html?to=85ed9abcfe82``

makefile 入门1

makefile 入门1目标 目标的语法非常简单targets: prerequisitesrecipes... 或者 targets: prerequisites ; recipesrecipes...当执行目标时,make会检测prerequisites中的所有文件是否存在,如果都存在则执行targets后…

详细介绍:【 C/C++ 算法】入门动态规划-----一维动态规划基础(以练代学式)

详细介绍:【 C/C++ 算法】入门动态规划-----一维动态规划基础(以练代学式)pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-fam…

iOS 26 能耗检测实战指南 如何监测 iPhone 电池掉电、Adaptive Power 模式效果与后台耗能问题(uni-app 与原生 App 优化必看)

本文结合 iOS 26 新增的 Adaptive Power 模式与电池界面功能,介绍如何检测 iPhone 能耗问题(包括启动耗电、后台耗电、动画特效与资源加载耗电等),并结合 Instruments、克魔等工具给出 uni-app 项目的实战优化指南…

Transformer的个人理解

Transformer工作原理 分词 文本进来之后,首先经过Tokenizer(分词器)分割成很多个token。每个token都会赋予一个从0开始的ID,用于后续索引。 然后通过一个embedding层,将token转换成一个多维向量,也叫做embedding…

国标GB28181平台EasyGBS如何实现企业园区视频监控一体化管理?

国标GB28181平台EasyGBS如何实现企业园区视频监控一体化管理?企业园区安防系统面临多品牌设备兼容难、系统孤立、管理效率低等痛点。本文详细探讨基于国标GB28181协议的EasyGBS视频平台如何为企业园区提供完整的视频监…

360环视硬件平台为什么推荐使用米尔RK3576开发板?

在汽车智能化和智慧安防快速发展的今天,360环视系统 已成为保障行车与场景安全、提升体验的重要技术。无论是自动泊车、驾驶辅助,还是智慧社区监控,核心诉求都是能够接入 多路摄像头,并通过高效的 推流 实现低延迟…

C语言弱函数

C语言弱函数project/ ├── core/ │ └── system_init.c // 核心框架代码,包含弱函数 ├── boards/ │ └── my_board.c // 板级特定代码,提供强函数 └── main.c // 主程序 /…

高质量票据识别数据集:1000张收据图像+2141个商品标注,支持OCR模型训练与文档理解研究

​获取更多高质量数据集,请访问典枢数据交易平台:https://dianshudata.com/引言与背景 在数字化转型的浪潮中,票据识别技术已成为金融、零售、餐饮等行业自动化处理的核心技术。传统的票据处理依赖人工录入,效率低…

1202_InnoDB中一条UPDATE语句的执行流程

InnoDB中一条UPDATE语句的执行流程可以概括为以下步骤和图示:下面是每个步骤的详细说明: 第一步:连接器与权限验证 (Client → Server Layer)建立连接:客户端应用程序(如Java程序、MySQL CLI)与MySQL服务器建立连…

1201_mysql查询语句select执行流程

查询语句select执行流程,如下图所示,其核心流程可概括为: flowchart TD A["客户端提交 SELECT 语句"] --> B["连接器<br>管理连接, 权限验证"] B --> C["查询缓存<br>(…

记录---vue3项目实战 打印、导出PDF

🧑‍💻 写在开头 点赞 + 收藏 === 学会🤣🤣🤣 一 维护模板 1 打印模板:<template> <div class="print-content"> <div v-for="item in data.detailList" :key="…

node.js安装(绿色版)

1、官方下载,选择【独立文件(.zip)】下载https://nodejs.org/zh-cn/download/ 2、解压到C:\Program Files\nodejs3、在安装目录下创建以下两个目录node_global(默认:C:\Program Files\nodejs) node_cache(默认:C…

selenium完整版一览 - 教程

selenium完整版一览 - 教程pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", …