TensorFlow 示例平方米转亩

TensorFlow 和 Keras 来构建一个简单的神经网络模型,用于将输入的平方米数值转换为对应的亩数。代码包括了数据准备、模型构建、编译、训练、评估以及绘制损失曲线的过程。下面我会详细解释每一部分TensorFlow 和 Keras 来构建一个简单的神经网络模型,用于将输入的平方米数值转换为对应的亩数。代码包括了数据准备、模型构建、编译、训练、评估以及绘制损失曲线的过程。下面我会详细解释每一部分

1. 数据准备与预处理

复制代码
平方米 = np.array([15, 30, 50, 100, 150, 300, 315, 666.66, 1000], dtype=float)
亩 = np.array([0.0225, 0.0450, 0.0750, 0.1500, 0.2250, 0.4500, 0.4725, 1.0000, 1.5000], dtype=float)
#将 平方米 数组的形状调整为一个列向量。
平方米 = 平方米.reshape(-1, 1)

2. 构建模型

构建了一个简单的神经网络,只有一个 Dense 层,输入是一个值,输出也是一个值。这个网络尝试找到输入(平方米)和输出(亩)之间的关系。

复制代码
layer = tf.keras.layers.Dense(units=1, input_shape=[1])  # 输入一个值,输出一个值
model = tf.keras.Sequential([layer])

3. 编译模型

这里使用了 Adam 优化器来最小化均方误差(MSE)。学习率设置为 0.1。Adam 优化器通常可以在较小的数据集上快速收敛。

复制代码
model.compile(optimizer=tf.keras.optimizers.Adam(0.1), loss='mean_squared_error')

4. 训练模型

这里训练模型 1000 个 epoch,每次迭代更新权重以减少损失函数。verbose=1 会显示每个 epoch 的训练进度。

复制代码
history = model.fit(平方米, 亩, epochs=1000, verbose=1)

5. 评估模型

这里循环通过每个输入数据,预测出相应的亩数并与实际值进行对比。这部分的输出将告诉你模型在每个输入数据点上的预测效果。

复制代码
print("预测结果:")
for c, f in zip(平方米, 亩):
    predicted_value = model.predict(np.array([[c]]))
    print(f"{c[0]} 平方米 => 实际: {f} 亩, 预测: {predicted_value[0][0]:.4f} 亩")

6. 绘制损失曲线

这部分代码绘制了训练过程中每个 epoch 的损失曲线,帮助你了解训练过程中的损失变化,判断模型的收敛情况。

复制代码
plt.plot(history.history['loss'])
plt.title('Model Loss')
plt.xlabel('Epoch')
plt.ylabel('Loss')
plt.show()

7. 完整代码

复制代码
import tensorflow as tf
import numpy as np
import matplotlib.pyplot as plt

# 1. 数据准备与预处理
# 输入数据 (平方米)对应亩
平方米 = np.array([15, 30, 50, 100, 150, 300, 315, 666.66, 1000], dtype=float)
亩 = np.array([0.0225, 0.0450, 0.0750, 0.1500, 0.2250, 0.4500, 0.4725, 1.0000, 1.5000], dtype=float)
平方米 = 平方米.reshape(-1, 1)
# 2. 构建模型
layer = tf.keras.layers.Dense(units=1, input_shape=[1])  # 输入一个值,输出一个值
model = tf.keras.Sequential([layer])
# 3. 编译模型
model.compile(optimizer=tf.keras.optimizers.Adam(0.1), loss='mean_squared_error')
 
# 4. 训练模型
history = model.fit(平方米, 亩, epochs=1000, verbose=1)
 
# 5. 评估模型
print("预测结果:")
for c, f in zip(平方米, 亩):
    predicted_value = model.predict(np.array([[c]]))
    print(f"{c[0]} 平方米 => 实际: {f} 亩, 预测: {predicted_value[0][0]:.4f} 亩")

# 6. 绘制损失曲线
plt.plot(history.history['loss'])
plt.title('Model Loss')
plt.xlabel('Epoch')
plt.ylabel('Loss')
plt.show()

8. 总结

该代码实现了一个基础的神经网络回归模型,用于预测面积之间的关系。通过训练,模型学习到了从平方米到亩的转换规律,并且可以进行准确的预测。

相关推荐
TG:@yunlaoda360 云老大2 小时前
腾讯WAIC发布“1+3+N”AI全景图:混元3D世界模型开源,具身智能平台Tairos亮相
人工智能·3d·开源·腾讯云
这张生成的图像能检测吗2 小时前
(论文速读)Fast3R:在一个向前通道中实现1000+图像的3D重建
人工智能·深度学习·计算机视觉·3d重建
兴趣使然黄小黄5 小时前
【AI-agent】LangChain开发智能体工具流程
人工智能·microsoft·langchain
出门吃三碗饭5 小时前
Transformer前世今生——使用pytorch实现多头注意力(八)
人工智能·深度学习·transformer
l1t6 小时前
利用DeepSeek改写SQLite版本的二进制位数独求解SQL
数据库·人工智能·sql·sqlite
ζั͡山 ั͡有扶苏 ั͡✾6 小时前
从零搭建 Data-Juicer:一站式大模型数据预处理与可视化平台完整教程
python·data-juicer
说私域6 小时前
开源AI智能名片链动2+1模式S2B2C商城小程序FAQ设计及其意义探究
人工智能·小程序
SkylerHu6 小时前
tornado+gunicorn部署设置max_body_size
python·tornado·gunicorn
开利网络6 小时前
合规底线:健康产品营销的红线与避坑指南
大数据·前端·人工智能·云计算·1024程序员节
非著名架构师7 小时前
量化“天气风险”:金融与保险机构如何利用气候大数据实现精准定价与投资决策
大数据·人工智能·新能源风光提高精度·疾风气象大模型4.0