机器学习速成课程 | 练习 | Google Development——编程练习:神经网络简介
神经网络简介
学习目标:
- 使用 TensorFlow
DNNRegressor
类定义神经网络 (NN) 及其隐藏层- 训练神经网络学习数据集中的非线性规律,并实现比线性回归模型更好的效果
在之前的练习中,我们使用合成特征来帮助模型学习非线性规律。
一组重要的非线性关系是纬度和经度的关系,但也可能存在其他非线性关系。
现在我们从之前练习中的逻辑回归任务回到标准的(线性)回归任务。也就是说,我们将直接预测 median_house_value
。
设置
首先加载和准备数据。
from __future__ import print_function
import math
from IPython import display
from matplotlib import cm
from matplotlib import gridspec
from matplotlib import pyplot as plt
import numpy as np
import pandas as pd
from sklearn import metrics
import tensorflow as tf
from tensorflow.python.data import Dataset
tf.logging.set_verbosity(tf.logging.ERROR)
pd.options.display.max_rows = 10
pd.options.display.float_format = '{:.1f}'.format
california_housing_dataframe = pd.read_csv("https://download.mlcc.google.com/mledu-datasets/california_housing_train.csv", sep=",")
california_housing_dataframe = california_housing_dataframe.reindex(
np.random.permutation(california_housing_dataframe.index))
def preprocess_features(california_housing_dataframe):
"""Prepares input features from California housing data set.
Args:
california_housing_dataframe: A Pandas DataFrame expected to contain data
from the California housing data set.
Returns:
A DataFrame that contains the features to be used for the model, including
synthetic features.
"""
selected_features = california_housing_dataframe[
["latitude",
"longitude",
"housing_median_age",
"total_rooms",
"total_bedrooms",
"population",
"households",
"median_income"]]
processed_features = selected_features.copy()
# Create a synthetic feature.
processed_features["rooms_per_person"] = (
california_housing_dataframe["total_rooms"] /
california_housing_dataframe["population"])
return processed_features
def preprocess_targets(california_housing_dataframe):
"""Prepares target features (i.e., labels) from California housing data set.
Args:
california_housing_dataframe: A Pandas DataFrame expected to contain data
from the California housing data set.
Returns:
A DataFrame that contains the target feature.
"""
output_targets = pd.DataFrame()
# Scale the target to be in units of thousands of dollars.
output_targets["median_house_value"] = (
california_housing_dataframe["median_house_value"] / 1000.0)
return output_targets
# Choose the first 12000 (out of 17000) examples for training.
training_examples = preprocess_features(california_housing_dataframe.head(12000))
training_targets = preprocess_targets(california_housing_dataframe.head(12000))
# Choose the last 5000 (out of 17000) examples for validation.
validation_examples = preprocess_features(california_housing_dataframe.tail(5000))
validation_targets = preprocess_targets(california_housing_dataframe.tail(5000))
# Double-check that we've done the right thing.
print("Training examples summary:")
display.display(training_examples.describe())
print("Validation examples summary:")
display.display(validation_examples.describe())
print("Training targets summary:")
display.display(training_targets.describe())
print("Validation targets summary:")
display.display(validation_targets.describe())
构建神经网络
神经网络由 DNNRegressor 类定义。
使用 hidden_units
定义神经网络的结构。hidden_units
参数会创建一个整数列表,其中每个整数对应一个隐藏层,表示其中的节点数。以下面的赋值为例:
hidden_units=[3,10]
上述赋值为神经网络指定了两个隐藏层:
- 第一个隐藏层包含 3 个节点。
- 第二个隐藏层包含 10 个节点。
如果我们想要添加更多层,可以向该列表添加更多整数。例如,hidden_units=[10,20,30,40]
会创建 4 个分别包含 10、20、30 和 40 个单元的隐藏层。
默认情况下,所有隐藏层都会使用 ReLu **函数,且是全连接层。
def construct_feature_columns(input_features):
"""Construct the TensorFlow Feature Columns.
Args:
input_features: The names of the numerical input features to use.
Returns:
A set of feature columns
"""
return set([tf.feature_column.numeric_column(my_feature)
for my_feature in input_features])
def my_input_fn(features, targets, batch_size=1, shuffle=True, num_epochs=None):
"""Trains a linear regression model of one feature.
Args:
features: pandas DataFrame of features
targets: pandas DataFrame of targets
batch_size: Size of batches to be passed to the model
shuffle: True or False. Whether to shuffle the data.
num_epochs: Number of epochs for which data should be repeated. None = repeat indefinitely
Returns:
Tuple of (features, labels) for next data batch
"""
# Convert pandas data into a dict of np arrays.
features = {key:np.array(value) for key,value in dict(features).items()}
# Construct a dataset, and configure batching/repeating
ds = Dataset.from_tensor_slices((features,targets)) # warning: 2GB limit
ds = ds.batch(batch_size).repeat(num_epochs)
# Shuffle the data, if specified
if shuffle:
ds = ds.shuffle(10000)
# Return the next batch of data
features, labels = ds.make_one_shot_iterator().get_next()
return features, labels
任务 1:训练神经网络模型
调整超参数,目标是将 RMSE 降到 110 以下。
运行以下代码块来训练神经网络模型。
我们已经知道,在使用了很多特征的线性回归练习中,110 左右的 RMSE 已经是相当不错的结果。我们将得到比它更好的结果。
在此练习中,您的任务是修改各种学习设置,以提高在验证数据上的准确率。
对于神经网络而言,过拟合是一种真正的潜在危险。您可以查看训练数据损失与验证数据损失之间的差值,以帮助判断模型是否有过拟合的趋势。如果差值开始变大,则通常可以肯定存在过拟合。
由于存在很多不同的可能设置,强烈建议您记录每次试验,以在开发流程中进行参考。
此外,获得效果出色的设置后,尝试多次运行该设置,看看结果的重复程度。由于神经网络权重通常会初始化为较小的随机值,因此每次运行结果应该存在差异。
解决方案
点击下方即可查看可能的解决方案
注意:在本次练习中,参数的选择有点随意。我们尝试了越来越复杂的组合,并进行了较长时间的训练,直到误差降到目标之下。这决不是最佳组合;其他组合可能会获得更低的 RMSE。如果您的目标是找到可以产生最小误差的模型,那么您需要使用更严格的流程,例如参数搜索。
dnn_regressor = train_nn_regression_model(
learning_rate=0.01,
steps=500,
batch_size=10,
hidden_units=[10, 2],
training_examples=training_examples,
training_targets=training_targets,
validation_examples=validation_examples,
validation_targets=validation_targets)
dnn_regressor = train_nn_regression_model(
learning_rate=0.01,
steps=500,
batch_size=10,
hidden_units=[10, 10],
training_examples=training_examples,
training_targets=training_targets,
validation_examples=validation_examples,
validation_targets=validation_targets)
dnn_regressor = train_nn_regression_model(
learning_rate=0.001,
steps=2000,
batch_size=100,
hidden_units=[10, 10],
training_examples=training_examples,
training_targets=training_targets,
validation_examples=validation_examples,
validation_targets=validation_targets)
dnn_regressor = train_nn_regression_model(
learning_rate=0.00001,
steps=100000,
batch_size=100,
hidden_units=[10, 10],
training_examples=training_examples,
training_targets=training_targets,
validation_examples=validation_examples,
validation_targets=validation_targets)
任务 2:用测试数据进行评估
确认您的验证效果结果经受得住测试数据的检验。
获得满意的模型后,用测试数据评估该模型,以与验证效果进行比较。
提示:测试数据集位于此处。
解决方案
与顶部代码类似,我们只需加载合适的数据文件、对其进行预处理并调用预测和 mean_squared_error 即可。
请注意,由于我们会使用所有记录,因此无需对测试数据进行随机化处理。
california_housing_test_data = pd.read_csv("https://download.mlcc.google.com/mledu-datasets/california_housing_test.csv", sep=",")
test_examples = preprocess_features(california_housing_test_data)
test_targets = preprocess_targets(california_housing_test_data)
predict_testing_input_fn = lambda: my_input_fn(test_examples,
test_targets["median_house_value"],
num_epochs=1,
shuffle=False)
test_predictions = dnn_regressor.predict(input_fn=predict_testing_input_fn)
test_predictions = np.array([item['predictions'][0] for item in test_predictions])
root_mean_squared_error = math.sqrt(
metrics.mean_squared_error(test_predictions, test_targets))
print("Final RMSE (on test data): %0.2f" % root_mean_squared_error)
Final RMSE (on test data): 66.89
机器学习速成课程编程练习参考链接:
https://developers.google.com/machine-learning/crash-course/exercises
上一篇: 设置密文在图片上1 jpeg
下一篇: ngx_lua安装有关问题,很急需要帮助
推荐阅读
-
thinkphp实现模模糊糊匹配(学习贵哥代码)
-
机器学习速成课程 | 练习 | Google Development——编程练习:神经网络简介
-
php学习??smarty
-
ubuntu-mysqldump出的数据库sql文件在另一机器的mysql中source导入结果不一致,表丢失
-
网站统计分析系统piwik(相仿google analytics),有用过的吗
-
phpmyadmin课程之linux下phpmyadmin的安装
-
编程语言排行榜下php越走越低呀
-
对于PHP程序初学者来说,有没有比较好的开源项目适合学习和深入的呢?
-
请PHP大侠推荐一本好的PHP课程书籍
-
Java多线程并发编程 并发三大要素