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

成为数据科学家之路,第一部分:数学

原文towardsdatascience.com/roadmap-to-becoming-a-data-scientist-part-1-maths-2dc9beb69b27https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/492ae0fb35397ff6690bc9518f937530.png简介数据科学无疑是当今最迷人的领域之一。在大约十年前机器学习取得重大突破之后数据科学在技术社区中迅速流行起来。每年我们都见证了曾经看似不可思议的强大工具。诸如Transformer 架构、ChatGPT、检索增强生成RAG框架以及最先进的计算机视觉模型——包括GANs——对我们世界产生了深远的影响。然而随着工具的丰富和围绕 AI 的持续炒作确定在追求数据科学职业生涯时应该优先考虑哪些技能可能会令人不知所措——尤其是对于初学者来说。此外这个领域要求极高需要大量的投入和毅力。在本文中我的目标是呈现一个详细的路线图概述在开始数据科学之旅时需要关注的数学关键领域。本文将专注于开始数据科学职业生涯所需的数学技能。是否根据你的背景和其他因素选择这条道路是值得的将在另一篇文章中讨论。数据科学——外部视角在许多方面数据科学作为一个独特的领域脱颖而出因为它需要跨越多个学科的一系列技能。在我看来维恩图是展示数据科学真正包含内容的优秀视觉表示https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/03a6fc53b1e4d79678b2f7e2b1dc4be7.png展示关键数据科学组件的维恩图如我们所见数据科学位于三个关键领域的交汇点数学、计算机科学和商业专业知识。虽然这三个组成部分都是必不可少的但我建议初学者主要关注前两个。推荐这样做的原因是坚实的数学和计算机科学基础对于任何数据科学家角色都是必不可少的。同时数据科学被应用于广泛的领域包括银行、电子商务、供应链、医疗保健、自动驾驶汽车等。因此你工作的特定商业领域可能会在你整个职业生涯中频繁变化。虽然理解特定商业领域仍然很有价值但这个因素往往是可变的。因此我强烈建议优先考虑数学和计算机科学作为核心技能。这些领域将是本文系列的焦点。动机数学构成了所有机器学习算法的基础性构建块。没有对数学的扎实理解就无法掌握这些算法是如何工作的。你是否可以在完全不了解机器学习模型如何工作的情况下训练和使用这些模型是的你可以。有众多优秀的工具和库——例如 Scikit-Learn、TensorFlow、PyTorch 和 Gym——只需几行代码就能训练复杂的模型。那么在这种情况下为什么还要费心学习数学呢理解算法在底层是如何工作的有助于你在选择给定任务中最合适的算法时做出明智的决定。它还使你能够识别其范围更容易地进行调试和优化并选择更好的参数。此外有了这些宝贵的知识你可以修改原始算法以更好地满足你的特定需求。https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/53c58d53f39f34e0b8541bad650d6460.png理解算法工作流程的优势此外许多算法都是建立在其他算法之上的因此掌握基本算法的基础知识将有助于理解更高级的算法。最后在数据科学职业生涯中经常需要回顾最新的科学出版物。一般来说机器学习文章和论文经常包含大量的数学符号和公式。为了完全理解它们的上下文坚实的数学基础是必不可少的。根据我概述的点我希望现在大家已经清楚地认识到学习数学的重要性。接下来让我们讨论作为有抱负的数据科学家需要培养的具体数学技能。01. 微积分微积分是一个庞大的领域包含了大量的美丽方程式、定理和概念。没有这些知识理解基本机器学习算法的内部工作原理几乎是不可能的。好消息是数据科学家不需要了解所有这些因为最重要的算法中只使用了少数几个关键概念。下面的图表展示了最初需要关注的必要知识https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/327e94028792f52153849f2f9c5560bd.png微积分路线图许多机器学习算法基于优化问题其目标是找到函数的最小值通常通过计算导数来实现。虽然积分在机器学习中并不常用但它们在统计学和概率论中仍然非常有用——这是我们将在本文稍后重点关注的另一个重要领域。简单来说积分是导数的逆运算。实际上积分和导数紧密相关许多定理都依赖于两者来证明关键概念。达到理解导数如何使用这一点将有助于你掌握随机梯度下降SGD算法这是大多数机器学习算法采用的基本方法。虽然算法不断进化许多科学论文依赖于高级数学概念但一旦你掌握了微积分基础它们就会容易得多。02. 线性代数线性代数是数学的另一个关键领域它专注于向量、向量空间和线性变换。https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/8f07e0c81d1fe31a6d54054ac9bcab52.png线性代数路线图在数据科学中数据可以以各种格式表示但最终它会被转换成数字向量这些向量被输入到预测模型中。向量也用于比较对象之间的相似性估计变量之间的相关性执行特征工程更新模型权重或编码单词的语义含义。鉴于其广泛的应用范围早期研究向量至关重要。下一个重要主题是矩阵它可以被视为将几个向量堆叠成表格的集合。矩阵用于表示表格数据或图。它们在神经网络中也得到广泛应用其中网络的一层可以表示为一个矩阵。这种矩阵表示使得计算更快因为许多数学方法都针对与矩阵更有效地工作进行了优化。矩阵的另一个重要应用是在解线性方程组。每个这样的系统都可以表示为一个矩阵方程Ax b。基于此有几种方法可以解这个方程基于矩阵的性质如乘法、求行列式或计算逆矩阵。https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/4865c661db3d76ea67f1908787d49ca7.png矩阵分解左侧的大矩阵表示为两个较小矩阵的乘积最后矩阵不仅可以表示表格数据还可以通过矩阵分解来压缩数据。这个过程涉及将原始矩阵表示为几个较小矩阵的乘积。这种方法在推荐系统中特别受欢迎其中用户和产品之间的大量关系可以存储为几个较小、更有效的矩阵的组合。03. 统计学在数据科学中**探索性数据分析EDA**是数据分析的重要组成部分涉及数据的探索、异常检测、变量之间关系的假设制定以及研究它们对预测变量的影响。所有这些都需要坚实的统计学基础。https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/0c7624dda501a89926d3bda315c54ab9.png统计路线图为了有效地描述数据必须研究基本描述性统计和表示数据的方法。这是数学中最简单但最重要的领域之一。概率论是计算机科学许多领域出现的另一个基本构建块。在机器学习的背景下有许多用于评估算法质量的指标其中许多基于概率定义如精确度、召回率和ROC AUC。甚至还有概率模型如朴素贝叶斯算法用于分类任务。此外经典概率论包括各种类型的数据分布其中正态分布尤为重要。其重要性不容小觑因为它可以应用于描述广泛的现实世界过程。最后**中心极限定理和置信区间**的引入为理解统计学中的下一个重要主题假设检验提供了基础。A/B 测试基于假设检验是数据科学中的另一个重要主题。A/B 测试的目标是确定在两个最初基于特定标准划分的对象组之间给定指标是否存在显著差异。例如想象一家超市进行一项实验以确定向其客户发送短信是否会增加总收入。首先整个客户数据库被随机分成两组确保没有现有的偏差。这些组被标记为 A 和 B。然后开始营销活动超市向 A 组中的所有客户发送短信而 B 组中的客户则没有收到任何沟通。在最初定义的时期后计算两组的收入。如果两组之间的收入存在显著差异考虑到初始设置那么我们可以得出结论发送短信对产生的收入有影响。https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/5908c38c05e976e34dec0610ab084515.pngA/B 测试工作流程提供的例子相当简化因为 A/B 测试背后的实际科学要复杂得多。尽管如此假设检验是 A/B 测试的一个基本组成部分因为它解释了背后的逻辑并提供了在不同场景下进行 A/B 测试的各种方法。04. 离散数学https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/3e8031652ef51863f3b0e4c4c3fc6dc8.png离散数学路线图在我个人的经验中离散数学与之前的数学分支相比是最容易学习的。正如其名称所暗示的离散数学研究的是变量是离散的不是连续的数学结构。许多书籍和课程通过从集合论开始介绍离散数学这是有道理的因为集合几乎无处不在用于正式定义其他结构简洁地表达复杂的数学约束以及正式证明各种陈述和定理。此外集合论中使用的符号在机器学习论文中得到广泛采用如下面的示例所示https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/33e41b835c036dff6105c9f76226d264.png关于用于强化学习的 NICE 算法的论文的一部分。来源NICE通过强化学习引导的整数规划实现鲁棒调度下一个重要的分支是关系和函数它们研究集合元素之间的关系。虽然在实际数据科学问题中很少遇到关系理论的直接应用但其知识仍然很有价值。这是因为其他领域的许多证明尤其是在图论中可以通过应用关系概念和属性来简化。布尔代数它处理作用于二元变量的布尔函数是另一个关键领域。有趣的是没有布尔代数就无法想象现代计算机。实际上在底层计算机只使用 0 和 1 进行操作所有计算都是基于布尔代数原理进行的。了解布尔代数有助于理解代码中的逻辑条件和运算符使用逻辑运算符在 SQL 和其他语言中过滤数据优化查询以及执行数据处理。组合数学是数学的一个分支专注于在有限数据结构中对对象进行计数和排列。这种知识对于估计进行实验所需的样本或试验数量、优化采样技术、将对象划分为子集或计算图中可能路径的数量非常有用。虽然表格仍然是数据表示中最受欢迎的格式但它们不能直接存储对象之间的关系。这就是图发挥作用的地方。图是一种数据结构由代表对象的顶点和存储它们之间关系的边组成。根据边的类型它可以指示一对顶点之间关系的存在或不存在或者存储表示关系的强度或弱度的权重。这种看似简单的结构由一个名为图论的研究领域支撑。图论研究各种类型的图及其属性例如根据与其他顶点的连接性将顶点分组到组件中或者找到两个顶点之间的最短路径。图的一个明显应用是社交网络的分析。一群人可以被看作是一个图其中每个顶点代表一个人连接它的边指向这个人认识的其他人。虽然这是讨论图时最常用的例子但它们的应用范围非常广泛不仅限于社交网络还扩展到任何存在对象之间关系的领域。特别是图论在物流优化问题中得到广泛应用。https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/dc23d87d86a77dfb9dd2d24372193772.png表示数据科学团队内部交互的图示例。顶点代表团队成员边表示他们之间的交互水平。我应该学习定理的证明吗这是在数学学习者中常见的疑问。我们讨论的四个数学块都包含大量经过严格证明的陈述和定理。挑战在于完全理解证明背后的逻辑往往需要相当多的时间。那么投资时间分析证明真的值得吗在我个人的经历中分析和深入参与证明在我的大学学习期间发挥了重要作用。一方面很明显毕业后我实际上并没有记住大多数那些证明——这是完全正常的因为我们的大脑倾向于忘记那些不经常回顾的信息。另一方面能够理解我在过去遇到的几乎所有数学定理背后的推理帮助我在面对新机器学习论文中的不熟悉陈述时不再感到害怕。这也激发了我探索那些陈述为何为真的欲望。此外这种方法促进了抽象思维这对于成为一名数据科学家来说非常重要。最后我的回答将是肯定的——你应该在学习基础数学时研究你遇到的数学定理的证明以成为一名数据科学家。在其他情况下*如果你没有太多时间学习*专注于最重要的证明或者只是尝试理解定理陈述背后的深层含义。*如果你根本不喜欢学习证明*问问自己你是否真的喜欢数学以及你是否确定要从事数据科学领域的工作。结论在本路线图中我们已经探讨了数据科学学习过程中最重要的四个数学分支。虽然文本和图表中展示的术语和概念列表可以进一步扩展但我专注于最基本的部分。需要认识到的是即使你对核心数学领域有很强的掌握仍然会遇到新的概念。这是完全正常的因为机器学习是不断发展的不可能详细涵盖所有内容。然而对基础数学概念有扎实的理解将使你能够更快地掌握新的方法和算法而这在当今的数据科学市场中才是真正重要的。在本系列的下一篇文章中我们将重点关注数据科学所需的软件工程和机器学习技能。https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/2e81c8871486c190ae5dd35c201e2850.png在接下来的文章中我们将探讨数据科学所需的软件工程和机器学习技能。资源NICE: 通过强化学习引导的整数规划实现鲁棒调度所有图片除非另有说明均为作者原创。

相关文章:

成为数据科学家之路,第一部分:数学

原文:towardsdatascience.com/roadmap-to-becoming-a-data-scientist-part-1-maths-2dc9beb69b27 https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/492ae0fb35397ff6690bc9518f937530.png 简介 数据科学无疑是当今最迷人的领域…...

Svelte 现实世界指南(四)

原文:zh.annas-archive.org/md5/14dc6d5ba3099ee8ed407418d0a0711b 译者:飞龙 协议:CC BY-NC-SA 4.0 第十五章:使用过渡实现无障碍 在过去两章中,我们学习了如何在 Svelte 中使用过渡。当正确使用时,过渡可…...

Mavlink协议解析:从Pixhawk飞控到QGC地面站的完整通信流程

Mavlink协议深度解析:构建Pixhawk与QGC的高效通信桥梁 当Pixhawk飞控的LED指示灯开始规律闪烁,QGC地面站的地图上突然出现了一个蓝色圆点——这看似简单的连接背后,隐藏着一套精密的通信语言体系。Mavlink协议就像无人机系统的神经网络&#…...

告别穿模与漂移!南洋理工团队提出HMR新框架:用视觉大模型对齐人体姿态

点击下方卡片,关注「3D视觉工坊」公众号选择星标,干货第一时间送达本文一作投稿发布 | 来源:3D视觉工坊「3D视觉从入门到精通」知识星球(点开有惊喜) !星球内有20多门3D视觉系统课程、300场顶会讲解、顶会论文最新解读、海量3D视觉…...

CPAL脚本自动化测试 ———— 深度解析Test Report系列函数与应用场景

1. 为什么我们需要定制化测试报告? 在车载网络测试领域,特别是涉及自动驾驶功能的验证时,一个标准的测试报告往往无法满足工程师的需求。想象一下,当你花了三天三夜跑完2000个测试用例后,拿到的报告却只有简单的"…...

OpenClaw与千问3.5-35B-A3B-FP8低成本方案:自建模型接口替代OpenAI高价调用

OpenClaw与千问3.5-35B-A3B-FP8低成本方案:自建模型接口替代OpenAI高价调用 1. 为什么需要替代OpenAI高价调用 去年冬天的一个深夜,我盯着OpenAI API账单上那个刺眼的数字——$127.83,这只是一个月的测试费用。当时我正在用OpenClaw做一个自…...

提升效率:用快马一键生成模块化openclaw控制代码库

最近在做一个机器人项目,需要控制openclaw机械爪完成各种抓取任务。刚开始自己从头写控制代码时,发现光是启动流程就要处理一堆底层细节,比如初始化通信、校准位置、设置默认参数等等,不仅重复劳动,还容易出错。后来尝…...

STM32标准库开发入门与实战指南

1. STM32入门指南:从零开始掌握标准库开发作为一名嵌入式开发者,我深知STM32的学习曲线有多陡峭。记得我第一次接触STM32时,面对密密麻麻的寄存器手册和复杂的开发环境,完全不知从何入手。经过多年的项目实践和教学经验&#xff0…...

OpenClaw跨平台控制:Qwen3.5-9B管理多台电脑

OpenClaw跨平台控制:Qwen3.5-9B管理多台电脑 1. 为什么需要跨设备自动化管理 去年夏天,我同时处理三个项目时遇到了一个典型问题:每天需要在三台不同电脑上重复执行数据同步、日志收集和报告生成。手动操作不仅耗时,还经常遗漏步…...

Vivado Linux版安装空间不足?手把手教你如何优化磁盘空间分配

Vivado Linux版安装空间优化实战指南:从130G到80G的瘦身方案 当你在Linux系统上第一次看到Vivado安装程序提示需要130GB以上的磁盘空间时,那种震惊感我至今记忆犹新。作为一名长期在ThinkPad X1 Carbon上工作的FPGA开发者,我深刻理解空间受限…...

STM32精准延时实现与Keil调试技巧

1. 精准延时在单片机开发中的重要性在STM32等嵌入式系统开发中,精准延时是基础但至关重要的功能。我最近调试一块自制的STM32开发板时,就遇到了需要精确控制时序的场景。比如在驱动LCD屏幕时,某些控制信号需要维持15ms的精确延时,…...

Winbond W25N/W25M系列SPI NAND Flash驱动开发指南

1. Winbond W25N系列SPI NAND Flash驱动库技术解析Winbond W25N系列(含W25N01GV、W25N02GV等)与W25M系列(如W25M02GW双芯片封装)是工业级高可靠性SPI NAND Flash存储器,广泛应用于嵌入式系统中替代传统并行NAND或eMMC方…...

DLSS Swapper:3步解锁游戏性能倍增的AI优化工具

DLSS Swapper:3步解锁游戏性能倍增的AI优化工具 【免费下载链接】dlss-swapper 项目地址: https://gitcode.com/GitHub_Trending/dl/dlss-swapper DLSS Swapper是一款专为PC游戏玩家设计的深度学习超级采样(DLSS)版本管理工具,通过智能环境诊断、…...

AI绘画工作流:OpenClaw调度千问3.5-35B-A3B-FP8生成SD提示词

AI绘画工作流:OpenClaw调度千问3.5-35B-A3B-FP8生成SD提示词 1. 为什么需要自动化提示词生成 在Stable Diffusion创作中,最耗时的环节往往不是渲染过程,而是反复调试提示词(prompt)。我曾在一次商业插画项目中&#…...

抖音视频批量下载终极指南:5分钟掌握免费去水印技巧

抖音视频批量下载终极指南:5分钟掌握免费去水印技巧 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support…...

OpenClaw截图分析进阶:千问3.5-9B识别UI元素与操作建议

OpenClaw截图分析进阶:千问3.5-9B识别UI元素与操作建议 1. 为什么需要截图分析能力? 上周我在测试一个内部工具时遇到了一个典型问题——某个按钮在特定分辨率下会消失不见。手动排查需要反复调整窗口尺寸并肉眼检查,效率极低。这时我想到了…...

嵌入式轻量级数值优化库:面向MCU的确定性参数寻优方案

1. 项目概述Optimization 是一个面向嵌入式平台的轻量级数值优化库,专为 Arduino 及兼容 MCU(如 STM32、ESP32、nRF52 等)设计,其核心目标是在资源受限环境下,对用户定义的单目标标量函数 f(x₁, x₂, ..., xₙ) 进行参…...

OpenClaw自动化测试:Kimi-VL-A3B-Thinking多模态交互验证框架

OpenClaw自动化测试:Kimi-VL-A3B-Thinking多模态交互验证框架 1. 为什么需要AI驱动的自动化测试 去年接手一个客户端项目时,我遇到了一个典型痛点——每次发版前的手动回归测试需要3个人天。更麻烦的是,UI微调导致的视觉差异很难通过传统断…...

嵌入式系统XIP技术:原理、实现与优化

1. XIP技术核心概念解析eXecute In Place(XIP)技术是现代嵌入式系统中的一项关键创新。简单来说,它允许CPU直接从非易失性存储器(如NOR Flash)中读取并执行代码,而无需先将代码复制到RAM中。这种技术最早应…...

GetQzonehistory:终极QQ空间回忆一键保存指南

GetQzonehistory:终极QQ空间回忆一键保存指南 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 还在担心QQ空间里那些珍贵的青春记忆会随着时间消失吗?GetQzonehis…...

边缘检测算法选型指南:从Sobel到Canny的5个实际场景对比(含医疗/自动驾驶案例)

边缘检测算法实战选型:医疗影像与自动驾驶场景下的Sobel与Canny深度评测 在计算机视觉领域,边缘检测作为图像处理的基础环节,直接影响着后续特征提取和目标识别的准确性。面对医疗影像分析、自动驾驶感知等对精度和实时性要求极高的场景&…...

Figma Make 提示词工程化:构建从布局、组件、交互到风格的稳定设计系统

1. 从零散到系统:为什么需要工程化提示词 刚开始用Figma Make做设计时,我和大多数人一样,每次生成页面都要重新写一遍提示词。最头疼的是明明想要类似的风格,结果生成的页面总是"飘忽不定"——今天按钮圆角是8px&#x…...

Python数据分析实战:用Seaborn绘制炫酷相关性热力图(附完整代码)

Python数据分析实战:用Seaborn绘制炫酷相关性热力图 数据分析工作中,相关性分析是理解变量间关系的核心技能。而热力图作为直观展示相关性的工具,已经成为数据科学家和商业分析师的标准配置。本文将带你从零开始,掌握用Seaborn绘…...

DICOM序列实时渲染从28fps到126fps:C++无锁队列+GPU命令缓冲复用+ROI局部重绘的工业级调优日志

第一章:DICOM序列实时渲染性能跃迁全景概览 现代医学影像工作流对DICOM序列的实时可视化提出严苛要求:从百层CT扫描到高分辨率MRI动态序列,传统CPU软渲染方案常遭遇帧率跌破15 FPS、交互延迟超300ms的瓶颈。近年来,GPU加速管线、零…...

OpenClaw安全防护指南:Qwen3.5-9B-AWQ-4bit执行权限管控

OpenClaw安全防护指南:Qwen3.5-9B-AWQ-4bit执行权限管控 1. 为什么需要安全防护? 当我第一次在本地部署OpenClaw对接Qwen3.5-9B-AWQ-4bit模型时,最让我后怕的是发现它竟然能直接删除我的工作目录。这个开源智能体框架赋予了AI像人类一样操作…...

Windows 11上保姆级教程:用Ollama本地部署DeepSeek-R1 8B,再也不用担心API费用和网络延迟了

Windows 11本地AI部署实战:OllamaDeepSeek-R1 8B全流程指南 在AI技术快速发展的今天,越来越多的开发者和中小企业开始关注如何在本地环境中部署和运行大型语言模型。对于预算有限但对数据隐私有高要求的团队来说,本地部署不仅能显著降低成本&…...

仅限首批内测开发者获取:CPython无GIL预编译二进制+无锁标准库API速查表(含ABI兼容性矩阵与降级熔断方案)

第一章:Python无锁GIL环境下的并发模型概览Python 的全局解释器锁(GIL)长期被视为多线程 CPU 密集型任务的瓶颈。然而,随着 CPython 3.13 的正式引入“实验性无锁 GIL”(--without-pymalloc 配合 --with-gildisabled 构…...

OpenClaw多终端同步:手机遥控Phi-3-mini-128k-instruct执行电脑任务

OpenClaw多终端同步:手机遥控Phi-3-mini-128k-instruct执行电脑任务 1. 为什么需要手机遥控电脑? 上周五晚上十点半,我正躺在沙发上刷手机,突然想起有个重要文档忘在办公室电脑里了。如果按传统方式,我需要&#xff…...

C++27执行策略演进全图谱(从C++17到C++27 TS23742的5次关键修订与ABI兼容性断崖预警)

第一章:C27执行策略的范式跃迁与标准定位C27正将执行策略(Execution Policies)从“并行化提示”升格为“可验证执行契约”,标志着标准库算法语义模型的根本性重构。这一转变不再仅依赖实现对std::execution::par_unseq等策略的启发…...

家庭知识库中心:OpenClaw+Qwen3.5-9B管理个人数字资产

家庭知识库中心:OpenClawQwen3.5-9B管理个人数字资产 1. 为什么需要家庭知识库 去年搬家时,我在整理纸质文件的过程中发现一个严重问题:孩子的疫苗接种记录、房产合同、医疗报告等重要文档分散在多个文件夹中,紧急情况下根本找不…...