使用LLMs大模型进行股票投资预测——能实现盈利还能自我反思并给出合理解释

news2025/1/17 6:03:49

前言

股市的变化难以预测,任何微小的变化都可能对股票走势产生影响,这种不确定性让投资者们感到困惑。因此,研究者们开始关注目前备受关注的大型模型技术,他们试图利用这些技术来高效地处理和分析大量的股市数据,从中挖掘出隐藏的规律和趋势。他们希望能够迅速捕捉到新信息对市场的即时影响,进而预测未来股价的走势,并为投资者提供决策支持。
在这里插入图片描述

近期,WWW2024会议上发布了一项关于使用大型模型进行股票预测的研究,该研究不仅实现了16.6%的收益率,还提供了决策的解释。这一研究致力于通过有效处理和分析大量的股市数据,挖掘隐藏的规律和趋势,从而预测未来股价走势。
论文地址:https://arxiv.org/pdf/2402.03659.pdf

传统的非生成式深度学习模型难以解释股票预测,而尽管大型语言模型(LLMs)能够生成人类可读的解释,但在股票预测方面仍然面临挑战。为了应对这一问题,作者提出了Summarize-Explain-Predict(SEP)框架,该框架利用自我反思的代理和Proximal Policy Optimization(PPO)方法来训练LLM以生成可解释的股票预测。通过SEP框架,可以优化LLM在股票分类任务中的预测准确性和Matthews相关系数,并在投资组合构建任务中证明其有效性。

简介

金融市场中的有效市场假设(EMH)认为股票价格反映了所有可获得的信息,并且只对新信息做出反应。为了预测未来的股票价格变动,投资者需要分析来自外部数据源的大量信息,但这对金融专业人士来说是一个沉重的工作负担。因此,许多人开始研究并尝试利用深度学习技术进行股票预测。然而,传统的深度学习方法通常被视为黑盒模型,在股票预测中难以解释其预测结果,这降低了它们在实际应用中的可用性。

最近,大型语言模型(LLMs)为解决这个问题提供了新的思路。然而,使用LLMs进行可解释的股票预测仍然面临着挑战。首先,社交文本的影响因素多样,需要模型具备权衡新信息影响的能力。其次,引入解释组件会使问题更加复杂,需要大量的金融专家样本来训练强化学习模型。这需要耗费大量的人力和成本,不利于规模化应用。
在这里插入图片描述
本文介绍了一个名为Summarize-Explain-Predict (SEP)的框架,用于自动化生成可解释的股票预测。该框架利用自反思代理和Proximal Policy Optimization (PPO)算法,通过自学习的方式让一个LLM模型学会如何生成股票预测和解释其推理过程。该框架通过将大量文本输入数据转化为要点形式的摘要信息,让LLM模型能够理解和权衡不同信息的影响,并生成最可能的股票预测和解释。实验证明,该框架在股票分类任务中的预测准确性和Matthews相关系数方面优于传统的深度学习和LLM方法。此外,该框架还可以应用于投资组合构建任务,生成可解释的股票权重,并通过投资组合指标验证其有效性。

文本的主要贡献包括:

  • 探索了在没有专家注释样本的情况下,教授LLM模型如何以可解释的方式权衡多个文本信息的局限性;
  • 提出了一种利用自反思代理和PPO技术的解决方案,使LLM模型能够自主学习如何生成可解释的股票预测;
  • 通过实验证明了SEP框架的有效性,并展示了经过微调的LLM模型在预测性能和解释质量方面的改进。通过在多个股票上生成定量权重来解决投资组合任务,并通过投资组合指标验证了该方法的有效性。

算法架构

文本分析在股票预测中的应用历程:早期研究使用不同的文本表示方法,如词袋、名词短语和命名实体,后来被结构化信息所取代。最近的研究则更注重增加其他形式的信息,如音频数据和公司关系图。
大型语言模型在金融领域的应用:BloombergGPT是最著名的金融领域的大型语言模型之一,其他研究也尝试使用自己的金融领域语言模型。最近的研究则探索使用大型语言模型通过指导调整或预训练模型来进行股票预测。本文则通过增加自我反思代理和PPO训练器来优化股票预测的语言模型。

实现方法

本文介绍了可解释的股票预测任务及其相关数据,并提出了SEP框架,包括Summarize模块、Explain模块和Predict模块。Summarize模块从非结构化文本输入中生成事实信息摘要,Explain模块通过自我反思迭代生成股票预测的解释,Predict模块则利用自动生成的注释样本微调LLM并生成置信度预测。这一框架的提出旨在提高股票预测的解释性和可靠性,为投资者提供更准确、更易理解的预测结果。
在这里插入图片描述

预备工作

本文旨在利用给定股票的文本语料库,预测下一个交易日的股票价格变动,并提供易于理解的解释。文本语料库包含了过去T天的文本数据,我们的目标是生成一个二进制的股票价格变动预测以及相应的解释。每个语料库都包含了变量数量的非结构化文本,我们需要从中提取要点信息。

我们构建了一个新的数据集,采用了ACL18 StockNet数据集的数据收集方法。原始数据集的时间跨度为2014年至2016年,我们收集了更新版本,覆盖了2020年至2022年。由于行业数量的扩大和推文数量的指数增长,我们选择了11个行业中排名前5的股票,总计55只股票。股价数据来源于Yahoo Finance,而推文数据则通过Twitter API收集。鉴于每天的推文数量庞大,我们使用了BERTopic进行聚类,以识别每天的代表性推文。这些代表性推文将作为所有模型的文本输入。

摘要生成

本模块的目标是从非结构化的输入文本中生成摘要信息。目前的大型语言模型已经具备了超越人类的摘要能力。为了避免超出字符限制,我们首先利用大型语言模型生成每天事实信息的点形式摘要。此外,在提示中,我们还提供了两个示例。
X t s = M X ( s , C t s ) . ( 1 ) {\bf X}_{t}^{s}={\bf M}_{X}\left(s,C_{t}^{s}\right).\quad(1) Xts=MX(s,Cts).(1)

解释生成

Explain模块的目标有两个方面:虽然模块的关键目标是为股票预测生成清晰的解释,但生成的解释也可以作为推理步骤,让LLM进行自我反思,以改进自己的预测。

解释提示

Explain模块的提示包含两个变量输入:指定的股票以及从上一个模块生成的提取的信息序列。给定这些输入,LLM生成响应第二天的价格预测,以及解释。我们将其形式化为:
Y t s = M E ( s , X t − T s , ⋅ ⋅ ⋅ , X t − 2 s , X t − 1 s ) . ( 2 ) \mathcal{Y}_{t}^{s}=M_{E}\left(s,X_{t-T}^{s},\cdot\cdot\cdot,X_{t-2}^{s},X_{t-1}^{s}\right).\quad(2) Yts=ME(s,XtTs,,Xt2s,Xt1s).(2)

与之前的摘要提示类似,我们从数据集中选择两个案例,并手动合成响应轨迹以用作少样本样本。此外,选择的两个示例案例具有一个积极和一个消极的运动标签,以避免任何多数标签偏差。

自我反思的过程

目前的LLM没有经过生成股票预测的训练,这可能会导致在上一步中错误地生成注释示例。为了解决这个问题,我们将LLM部署为一个自主代理,通过一个自我反思循环,可以迭代地改进其过去的响应。
在这里插入图片描述
对于不正确的样本,然后我们给定其之前的输入和输出提示LLM为每次迭代生成反馈,我们将其称为短期记忆。反馈应该清楚地解释它在之前的推理中哪里出了问题,并提出一个高级计划来减轻下一次迭代的失败。总体的形式如下:
r t , i s = M R ( s , X t − T s , ⋯   , X t − 2 s X t − 1 s , Y t , i s ) . ( 3 ) \mathbf{r}_{t,i}^{s}=M_{R}\left(s,\mathbf{X}_{t-T}^{s},\cdots,\mathbf{X}_{t-2}^{s}\mathbf{X}_{t-1}^{s},{\cal{Y}}_{t,i}^{s}\right).\quad(3) rt,is=MR(s,XtTs,,Xt2sXt1s,Yt,is).(3)
对于每次迭代,LLM从其失败中吸取的教训,添加到其长期记忆。
y t , i s = M E ( s , X t − T s ,   ⋅   ⋅ ⋅ X t − 2 s , X t − 1 s , R t , i s ) . ( 4 ) \mathcal{y}_{t,i}^{s}=M_{E}\left(s,\mathbf{X}_{t-T}^{s},\ \cdot\ \cdot\cdot\mathbf{X}_{t-2}^{s},\mathbf{X}_{t-1}^{s},\mathbf{R}_{t,i}^{s}\right).\quad(4) yt,is=ME(s,XtTs,  Xt2s,Xt1s,Rt,is).(4)

模型微调

本文利用类似RLHF的三步过程来微调LLM。在训练过程中,我们使用反射的二进制评估来选择“更好”的响应,而不是人工反馈。
在这里插入图片描述
在第一步中,我们收集了演示数据,这些数据是从初始迭代中正确预测的样本中提取的。这些样本没有对应的“错误”回答,因为它们仅仅是从最初的提示中提取的。这些样本被用于进行有监督微调。

在第二步中,我们收集了包含成对正确和不正确的响应数据。这些数据用于训练奖励模型,该模型学习将更高的奖励分数分配给正确的回答。
L ( θ ) = − E ( x , y w , y l , s , t ) ∼ D [ log ⁡ ( σ ( r θ ( x t s , y w , t s ) − r θ ( x t s , y l , t s ) ) ) ] ( 5 ) {\mathcal{L}}(\theta) =-E_{(x,y_{w},y_{l,s,t)}}{\sim}D\left[\log\left(\sigma\left(r_{\theta}\left(\mathbf{x}_{t}^{s},\mathbf{y}_{w,t}^{s}\right)-r_{\theta}\left(\mathbf{x}_{t}^{s},\mathbf{y}_{l,t}^{s}\right)\right)\right)\right]\quad(5) L(θ)=E(x,yw,yl,s,t)D[log(σ(rθ(xts,yw,ts)rθ(xts,yl,ts)))](5)

第三步,使用PPO对训练好的策略进行优化。我们首先使用监督策略初始化模型,并使用它为从整个数据集随机选择的样本生成预测。接下来,奖励模型用于为每个响应生成奖励。然后,我们尝试通过最大化整体回报来优化PPO模型。
L ( ϕ ) = − E ( x , y ^ , s , t ) ∼ D π ϕ R L = [ r θ ( x t s , y ^ t s ) − β l o g π ϕ R L ( y ^ t s ∣ x t s ) π S F T ( y ^ t s ∣ x t s ) ] ( 6 ) \mathcal{L(}\phi)=-{{{\mathrm{E}}}}\big(\mathbf{x,}\hat{y},s,t\big)\sim\mathcal{D}_{\pi_{\phi}^{R L}}=\left[r_{\theta}\left({\bf x}_{t}^{s},\hat{\mathcal{y}}_{t}^{s}\right)-\beta\mathrm{log}\frac{\pi_{\phi}^{RL}\left(\hat{\mathcal{y}}_{t}^{s}|{\bf x}_{t}^{s}\right)}{\pi^{SFT}\left(\hat{\mathcal{y}}_{t}^{s}|{\bf x}_{t}^{s}\right)}\right]\quad(6) L(ϕ)=E(x,y^,s,t)DπϕRL=[rθ(xts,y^ts)βlogπSFT(y^tsxts)πϕRL(y^tsxts)](6)
我们注意到,目标包括一个附加项,惩罚训练策略和监督策略之间的KL分歧,这用于阻止策略坍缩成单一模式,并防止其生成与原始参考模型太不同的响应。

基于置信度抽样

在推理过程中,首先使用预训练的LLM对非结构化输入文本进行总结。然后,我们使用经过训练的策略从总结的事实生成第二天的预测。为了生成预测,我们使用best-of-𝑛采样器,在该采样器中,我们生成𝑛响应,并使用奖励模型的分数来选择最佳响应。

实验

本文评估了SEP模型在股票预测任务中的性能,并回答了三个研究问题:

Q1:SEP模型在分类准确性和解释质量方面如何与传统深度学习和其他LLM方法相比?

Q2:每个提出的组件如何帮助提高SEP模型的性能?

Q3:SEP框架是否足够通用,可用于其他金融相关任务,如可解释的投资组合构建?

实验设置

基线:
作者将SEP模型与传统深度学习模型以及经过微调的大型语言模型进行比较,并使用预测准确率和Matthews相关系数作为评估指标。基准模型包括:VAE+Attention、GRU+Attention、Transformer、GPT-3.5-turbo、Vicuna-7b-v1.5、FinGPT-Forecaster。

此外,SEP框架的一个关键特征是Summarize模块,它从非结构化推文中提取关键信息,供LLM基于其预测。对于LLM实验,我们报告了删除这些案例之前和之后的结果。在实践中,这可以被视为LLMs的一个好处,因为它能够主动判断它没有足够的信息来进行预测,投资者可以选择寻找更多的信息来进行分析,或者不进行当天的投资。

实现细节:
我们使用OpenAI GPT-3.5-turbo-16k模型对每个行业的前1名股票进行训练,其余股票使用Vicuna-13b-v1.5-16k模型。预测模型训练时使用Vicuna-7b-v1.5-16k进行训练,LLM模型使用trl进行训练。所有组件的训练都使用4位量化的LoRA进行。在推理时,我们采用n=4进行n-shot采样。最佳响应将作为选择的输出进行最终比较。

效果对比:
在这里插入图片描述
在预测准确性方面,SEP模型在使用GPT生成的解释上表现最佳,MCC指标也优于其他模型。在解释生成方面,SEP模型通过自我反思和强化学习,能够生成更好的解释,提高了模型的可解释性。
在这里插入图片描述
根据我们的分析,我们可以得出以下结论:

  1. 通用性指标(如信息一致性)得分最高,这使我们能够比较不同语言模型的相对性能。

  2. 尽管预测准确率仍然是首要指标,但即使预测错误,所有语言模型都能提供高质量的解释,这为投资者提供了更多的信息以做出决策。

  3. SEP模型在所有指标上得分最高。通过自我反思和强化学习,SEP模型能够内在地教导模型更好地比较因素以提高预测准确性,这使其在股票预测任务中表现出色。

消融分析:
在这里插入图片描述
本文评估了三个组件的效率:Summarize、Explain和Predict模块。Summarize模块通过提取重要的事实信息来减少输入文本的噪音和长度。Explain模块通过自我反思生成注释样本,提高了模型的预测准确性。Predict模块的消融研究表明,去除非信息性文本可以提供最佳结果。同时,使用最多共享的文本比随机抽样更好。最后,Explain模块的自我反思可以生成更多的决定性和正确的注释样本,用于Fine-tuning。

在指导调整过程中,加入解释组件(从SEP(二进制)到SEP(无PPO))平均提高了6.9%的准确性,可能是因为调整LLM以生成解释,从而引发LLM的推理过程,提高了预测准确性。

指导调整变体(SEP(无PPO))与基础模型(Vicuna模型)的结果非常相似,可能是因为样本在反射迭代之前(即图4中的步骤1)被采集,这些样本是基础模型已经能够处理的“简单”样本。

PPO强化学习(从SEP(无PPO)到SEP(1-shot))的改进最大,平均提高了14.8%,强调了PPO训练器在教授LLM更有效地生成股票预测方面的能力。此外,n-shot采样使用学习的奖励模型加权选择最佳输出,平均改进3.0%(从SEP(1-shot)到SEP(Ours)),进一步证明了PPO过程中训练的奖励模型的有用性。
在这里插入图片描述

投资组合优化

SEP框架能够教会LLM以二进制方式权衡输入文本中的信息。通过使用SEP框架对LLM进行微调,我们进一步探索了其泛化能力,使其能够在定量上权衡其自动生成的解释中的信息,以生成股票投资组合权重。我们使用与上述相同的方法对LLM进行微调,但这次输入信息是每天篮子中所有生成的解释。为了减少LLM需要权衡的股票数量并防止负权重(从而设置无卖空约束[37]),我们只筛选出预测为正的股票。然后,我们提示LLM根据每只股票的前景生成投资组合权重。我们将两组生成的权重输入到PPO训练器中,选择利润更高的一组作为“更好”的响应。我们比较了由三种不同LLM生成的投资组合的表现:GPT-3.5-turbo、Vicuna和我们微调的SEP模型。我们还包括了三个基准:1/N投资组合(篮子中的11只股票以相等权重购买)[14]、标准普尔500指数和仅买入预测为正的股票(Positive-Only)。我们使用四个指标评估投资组合的表现:总收益(简单地将每天的收益相加)、累计收益(评估期间重新投资任何额外的利润或损失后的最终收益)、利润的标准差和年化夏普比率[45]。从表5中可以看出,仅买入预测为正的股票的投资组合已经展现出良好的表现。
在这里插入图片描述
在这里插入图片描述
我们可以观察到:

标准差结果显示,1/N和市场指数的投资组合方法包含更多的股票,能够更均匀地分散股价波动,但它们的夏普比率仍然低于其他模型,表明风险回报比较低。

预训练的LLM模型(如GPT-3.5和Vicuna)在大多数指标上表现优于仅考虑正面因素的投资组合,显示了使用LLM在信息之间进行权衡以产生投资组合权重的能力。

我们的SEP模型在大多数投资组合指标上表现优于其他方法,并在标准差方面达到可比较的性能,展示了我们SEP框架的有效性。此外,LLM模型能够解释生成的投资组合权重,增加了结果的可解释性和可信度。

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

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

相关文章

c++基础语法—————默认成员函数

文章目录 一、构造函数(初始化)1.构造函数的名称与类名相同,没有返回类型,可以有参数。2.对象实例化时,编译器自动调用构造函数进行初始化3.若类中没有显示定义一个用户的构造函数,编译器则会自动生成一个默…

[LVGL]:MACOS下使用LVGL模拟器

如何在MACOS下使用lvgl模拟器 1.安装必要环境 brew install sdl2查看sdl2安装位置: (base) ➜ ~ brew list sdl2 /opt/homebrew/Cellar/sdl2/2.30.1/bin/sdl2-config /opt/homebrew/Cellar/sdl2/2.30.1/include/SDL2/ (78 files) /opt/homebrew/Cellar/sdl2/2.3…

计算机系统·浮点数

浮点数 理解含有小数值的二进制数 定点表示方法 十进制:以小数点为分界线,小数点左边数字的权重是10的正幂,小数点右边数字的权重是10的负幂。如图所示 二进制:小数点左边数字的权重是2的正幂,小数点右边数字的权重…

免费阅读篇 | 芒果YOLOv8改进111:注意力机制CBAM:轻量级卷积块注意力模块,无缝集成到任何CNN架构中,开销可以忽略不计

💡🚀🚀🚀本博客 改进源代码改进 适用于 YOLOv8 按步骤操作运行改进后的代码即可 该专栏完整目录链接: 芒果YOLOv8深度改进教程 该篇博客为免费阅读内容,YOLOv8CBAM改进内容🚀🚀&am…

Exam in MAC [容斥]

题意 思路 正难则反 反过来需要考虑的是: (1) 所有满条件一的(x,y)有多少对: x 0 时,有c1对 x 1 时,有c对 ...... x c 时,有1对 以此类推 一共有 (c2)(c1)/2 对 (2) 符合 x y ∈ S的有多少对&#xff1a…

深度学习每周学习总结P1(pytorch手写数字识别)

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 | 接辅导、项目定制 目录 0. 总结1. 数据导入部分2. 模型构建部分3. 训练前的准备4. 定义训练函数5. 定义测试函数6. 训练过程 0. 总结 总结: 数据导入部分&a…

Jmeter进行http接口测试

🍅 视频学习:文末有免费的配套视频可观看 🍅 关注公众号【互联网杂货铺】,回复 1 ,免费获取软件测试全套资料,资料在手,涨薪更快 本文主要针对http接口进行测试,使用 jmeter工具实现…

Jenkins自定义镜像推送到Harbor仓库

之前Jenkins需要推送jar包到远程到目标服务器再进行构建 现在Jenkins容器内部可以直接使用Docker了 直接在Jenkins构建好推送到Harbor仓库上,然后不管是哪台目标服务器,只需要去Harbor仓库拉取镜像即可。 修改Jenkins任务 将代码检测下面的远程服务器步…

UI 学习 三 可访问性 UX

设计、交流和实现不同领域内容的易访问性决策,涉及到一系列考虑因素,以达到更容易访问的产品体验。 Material使用的框架借鉴了WCAG标准和行业最佳实践,以帮助任何人预测、计划、记录和实现可访问体验。 下面描述的三个阶段有助于将可视化UI…

SIMATIC C7-635西门子触摸屏维修6ES7635-2EB02-0AE3

西门子工控机触摸屏维修C7-626/P西门子控制面板维修DP Panel 6ES7626-1DG03-0AE3;6ES7626-2DG04-0AE3 SIMATIC HMI移动面板维修(西门子面板)可轻松进行电源管理与操作,成为移动应用的可能之选。该面板支持线缆或 Wi-Fi 通信&…

Weblogic 常规渗透测试环境

测试环境 本环境模拟了一个真实的weblogic环境,其后台存在一个弱口令,并且前台存在任意文件读取漏洞。分别通过这两种漏洞,模拟对weblogic场景的渗透。 Weblogic版本:10.3.6(11g) Java版本:1.6 弱口令 环境启动后…

数字孪生与智慧城市:实现城市治理现代化的新路径

随着信息技术的迅猛发展,智慧城市已成为城市发展的必然趋势。数字孪生技术作为智慧城市建设的重要支撑,以其独特的优势为城市治理现代化提供了新的路径。本文将探讨数字孪生技术在智慧城市中的应用,以及如何实现城市治理的现代化。 一、数字…

OJ_还是畅通工程

题干 #include <iostream> #include <vector> #include <algorithm> using namespace std;//并查集的应用&#xff1a;判断图的连通性int set[10001]; //i下标是集合数据编号,set[i]是i的父亲的编号 //若i是根&#xff0c;可令set[i] i void InitDisjointSe…

Docker容器化技术(使用Dockerfile制作Nginx镜像)

编写Dockerfile制作Web应用系统nginx镜像&#xff0c;生成镜像名为nginx:v1.1&#xff0c;并推送其到私有仓库。 1、基于centos7基础镜像&#xff1b; 2、指定作者为Chinaskill&#xff1b; 3、安装nginx服务&#xff0c;将提供的dest目录传到镜像内&#xff0c;并将de…

案例分析篇00-【历年案例分析真题考点汇总】与【专栏文章案例分析高频考点目录】(2024年软考高级系统架构设计师冲刺知识点总结-案例分析篇-先导篇)

专栏系列文章&#xff1a; 2024高级系统架构设计师备考资料&#xff08;高频考点&真题&经验&#xff09;https://blog.csdn.net/seeker1994/category_12593400.html 案例分析篇01&#xff1a;软件架构设计考点架构风格及质量属性 案例分析篇11&#xff1a;UML设计考…

YOLO学习

至少不比原来差 网格大小&#xff1a;13、26、52 不同感受野匹配 损失函数是对数 二分类

通过路由器监控,优化网络效率

路由器是网络的基本连接组件&#xff0c;路由器监控涉及将路由器网络作为一个整体进行管理&#xff0c;其中持续监控路由器的性能、运行状况、安全性和可用性&#xff0c;以确保更好的操作和最短的停机时间&#xff0c;因此监控路由器至关重要。 为什么路由器监控对组织很重要…

面试相关问题准备

一.MySql篇 1优化相关问题 1.1MySql中如何定位慢查询&#xff1f; 慢查询的概念&#xff1a;在MySQL中&#xff0c;慢查询是指执行时间超过一定阈值的SQL语句。这个阈值是由long_query_time参数设定的&#xff0c;它的默认值是10秒1。也就是说&#xff0c;如果一条SQL语句的执…

物联网技术在农药化肥行业的远程监控解决方案

物联网技术在农药化肥行业的远程监控解决方案 随着物联网技术的日益成熟&#xff0c;其在农药化肥行业的应用呈现出广阔的前景。通过物联网远程监控解决方案&#xff0c;可以实现生产、存储和施用环节的全程智能化管理&#xff0c;大大提高行业效率和环保水平。 通过物联网云…

CleanMyMac X2024永久免费的强大的Mac清理工具

作为产品功能介绍专员&#xff0c;很高兴向您详细介绍CleanMyMac X这款强大的Mac清理工具。CleanMyMac X具有广泛的清理能力&#xff0c;支持多种文件类型的清理&#xff0c;让您的Mac始终保持最佳状态。 系统垃圾 CleanMyMac X能够深入系统内部&#xff0c;智能识别并清理各种…