gpt4 book ai didi

python - Tensorflow 2 坐标分类器

转载 作者:行者123 更新时间:2023-11-30 08:57:05 24 4
gpt4 key购买 nike

我是一名尝试机器学习的新手。我看到了这个仓库https://github.com/jbp261/Optimal-Classification-Model-of-BLE-RSSI-Dataset并想重复类似的实验。

所以我有 2 个接收器,想要对给定的 Rssi 值最接近哪一个进行分类。我捕获了一些训练数据并定义了区域 0(靠近信标 1)和区域 1(靠近信标 2)。

我使用 keras 构建了一个模型(也尝试使用 RandomForest,效果很好),但即使以 0.8 的精度评估基础训练数据,我也会得到 50% 的错误预测。

batch_size = 100

#reading the input samples and separating the input from the outputs
dataframe = pd.read_csv("C:\aaa\Log.csv")
labels = dataframe.pop('result')

#creating the dataset from the data
ds = tf.data.Dataset.from_tensor_slices((dict(dataframe), labels))
ds = ds.batch(batch_size)

feature_columns = []
headers = dataframe.columns.tolist()

# numeric cols
for header in headers:
temp = feature_column.numeric_column(header)
#feature_columns.append(feature_column.bucketized_column(temp, boundaries=[-70, -60, -50, -40 , -30])) tried also this
feature_columns.append(temp)

feature_layer = tf.keras.layers.DenseFeatures(feature_columns)

model = tf.keras.Sequential([
feature_layer,
layers.Dense(128, activation='relu'),
layers.Dense(128, activation='relu'),
layers.Dense(2, activation='sigmoid')
])

model.compile(optimizer='adam',
loss='binary_crossentropy',
metrics=['accuracy'])

model.fit(ds, epochs=20)


test_ds = tf.data.Dataset.from_tensor_slices((dict(dataframe), labels))
test_ds = test_ds.batch(batch_size)

loss, accuracy = model.evaluate(test_ds)
print("Accuracy", accuracy)

最佳答案

model.fit()添加一些验证(简单的方法是 validation_split=0.5 或您想要分割的任何百分比。)这会获取一些数据,将其与训练数据分开,并且仅在纪元结束后使用它来查看网络对数据的执行情况以前从未见过。这样您将看到损失、准确性、validation_loss和validation_accuracy。后两者更好地反射(reflect)了模型在实际使用中的表现。

一旦开始使用该指标,您就可以查看是否过度拟合,或者对网络所做的更改是否确实有帮助。

关于python - Tensorflow 2 坐标分类器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56169852/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com