news 2026/2/6 21:12:04

【小白笔记】梯度下降(Gradient Descent)来训练模型

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【小白笔记】梯度下降(Gradient Descent)来训练模型

importnumpyasnp# 读取训练样本数 kk=int(input())# 读取训练数据:共 k*4 个整数(每样本 3 特征 + 1 标签)data=list(map(int,input().split()))# 读取预测样本数 nn=int(input())# 读取待预测数据:共 n*3 个整数(每样本 3 特征)pred_data=list(map(int,input().split()))# 构建训练集 x (特征) 和 y (标签)x=[]y=[]foriinrange(k):start=i*4feature=data[start:start+3]# 前3个是特征price=data[start+3]# 第4个是价格(标签)x.append(feature)y.append(price)x=np.array(x,dtype=float)# 转为浮点型(梯度下降需要)x=np.c_[np.ones(x.shape[0]),x]# 添加偏置列(全1)y=np.array(y,dtype=float)# ========== 梯度下降替代正规方程 ==========m,p=x.shape# m: 样本数, p: 特征数(含偏置)theta=np.zeros(p)# 初始化参数 theta 为 0learning_rate=0.01# 学习率(可调)num_iterations=10000# 迭代次数(可调)# 梯度下降主循环for_inrange(num_iterations):# 计算预测值y_pred=x @ theta# 计算梯度:(1/m) * X^T (Xθ - y)gradient=(1/m)*x.T @(y_pred-y)# 更新参数theta=theta-learning_rate*gradient# ========== 预测部分(保持不变)==========x_pred=[]foriinrange(n):start=i*3feature=pred_data[start:start+3]x_pred.append(feature)x_pred=np.array(x_pred,dtype=float)x_pred=np.c_[np.ones(x_pred.shape[0]),x_pred]# 添加偏置列# 使用学到的 theta 进行预测y_pred=x_pred @ theta y_pred_rounded=[round(i)foriiny_pred]# 输出结果(拼接成字符串)print(''.join(map(str,y_pred_rounded)))

🔧 关键改动说明

原代码(正规方程)新代码(梯度下降)
theta = np.linalg.inv(x.T@x)@x.T@yfor循环迭代更新theta
不需要设置超参数需要设置learning_ratenum_iterations
一步求解多次迭代逼近最优解

⚙️ 超参数建议(可根据数据调整)

  • learning_rate
    • 如果 loss 震荡或发散 → 减小(如0.001
    • 如果收敛太慢 → 增大(如0.1
  • num_iterations
    • 一般1000~10000足够;也可加早停机制(当 loss 变化很小时停止)

💡提示:如果特征尺度差异大(比如一个特征是“面积=100”,另一个是“房间数=3”),建议先做特征标准化(如(x - mean)/std),否则梯度下降会很慢。但本题输入是整数且未说明范围,暂时省略。


✅ 示例输入/输出(验证用)

输入

2 1 2 3 10 4 5 6 30 1 7 8 9
  • 训练样本1: [1,2,3] → 10
  • 训练样本2: [4,5,6] → 30
  • 预测样本: [7,8,9] → ?

输出(近似):

50

(因为模型学到大致是y ≈ x1 + x2 + x3,7+8+9=24?但实际拟合可能不同;若用正规方程得精确解,梯度下降应接近)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/6 13:07:27

EmotiVoice支持语音情感风格迁移学习

EmotiVoice:让AI语音拥有情感与个性 在虚拟助手机械地念出天气预报、游戏角色用千篇一律的语调说出台词时,我们是否曾期待过——机器的声音也能像真人一样,因喜悦而轻快,因悲伤而低沉?如今,这一设想正随着…

作者头像 李华
网站建设 2026/2/5 14:57:09

定期第三方安全审计:EmotiVoice质量保证

定期第三方安全审计:EmotiVoice质量保证 在虚拟助手越来越“会来事儿”、数字人开始讲冷笑话的今天,语音合成早已不是“把字念出来”那么简单。用户期待的是有情绪、有性格、甚至能共情的声音——一句话说得是惊喜还是嘲讽,语气差一点&#x…

作者头像 李华
网站建设 2026/2/5 16:15:06

不同职业人群对EmotiVoice的应用需求分析

不同职业人群对EmotiVoice的应用需求分析 在远程教学反复卡顿、游戏NPC对话机械重复、有声书录制耗时费力的今天,我们越来越意识到:语音交互不能只是“能听清”,更要“听得进”。真正打动人的声音,需要情绪的起伏、语气的变化和个…

作者头像 李华
网站建设 2026/2/6 20:56:43

手机系统预装应用包彻底删除

本文以华为手机 HarmonyOS 为例。 HarmonyOS/EMUI 系统预装应用删除 华为 HarmonyOS 与 EMUI 系统均为基于安卓底层架构的自主定制系统,二者运行逻辑与原生安卓保持一致。卸载系统预装应用需调用系统级操作权限,该权限通常被称为 ROOT。 鉴于华为已关闭…

作者头像 李华
网站建设 2026/2/4 19:53:58

EmotiVoice能否实现多人对话同步生成?技术可行性评估

EmotiVoice能否实现多人对话同步生成?技术可行性评估 在虚拟角色日益“活”起来的今天,用户不再满足于听到一段机械朗读——他们希望看到两个AI角色展开一场有来有往、情绪起伏的真实对话。这种需求催生了一个关键问题:现有的开源语音合成模型…

作者头像 李华
网站建设 2026/2/5 20:50:28

FusionCompute 8.0 实验环境搭建:完整资源获取与部署指南

FusionCompute 8.0 实验环境搭建:完整资源获取与部署指南 【免费下载链接】FusionCompute8.0资源下载指南分享 本仓库提供了一个详细的资源文件,内含百度网盘连接及提取码,以及详细的资源列表,方便您学习和使用FusionCompute 8.0。…

作者头像 李华