Task205:模型搭建和模型评估

思维导图

在这里插入图片描述

代码

import pandas as pd
import numpy as np
import seaborn as sns
import matplotlib.pyplot as plt
#from Ipython.display import Image


train=pd.read_csv('D:\\pythondata\\result.csv')
print(train.shape)
#对缺失值进行填充
train['Cabin']=train['Cabin'].fillna('NA')
train['Embarked']=train['Embarked'].fillna('S')

train['Age']=train['Age'].fillna(train['Age'].mean())
#检查缺失值的比例
print(train.isnull().mean().sort_values(ascending=False))
#可以把分类变量变成0-1形式,虚拟变量的转换
data=train[['Pclass','Sex','Age','SibSp','Parch','Fare','Embarked']]
data=pd.get_dummies(data)
print(data.head(5))

#切割训练集和测试集
from sklearn.model_selection import train_test_split

X=data
y=train['Survived']
X_train,X_test,y_train,y_test=train_test_split(X,y,stratify=y,random_state=0)
print(X_train.shape,X_test.shape)

from sklearn.linear_model import LogisticRegression
from sklearn.ensemble import RandomForestClassifier
lr=LogisticRegression()
lr.fit(X_train,y_train)
print("Training set score:{:.2f}".format(lr.score(X_train,y_train)))
print("Testing set score:{:.2f}".format(lr.score(X_test,y_test)))

lr2 = LogisticRegression(C=100)
lr2.fit(X_train, y_train)
print("Training set score: {:.2f}".format(lr2.score(X_train, y_train)))
print("Testing set score: {:.2f}".format(lr2.score(X_test, y_test)))

# 默认参数的随机森林分类模型
rfc = RandomForestClassifier()
rfc.fit(X_train, y_train)
print("Training set score: {:.2f}".format(rfc.score(X_train, y_train)))
print("Testing set score: {:.2f}".format(rfc.score(X_test, y_test)))
# 调整参数后的随机森林分类模型
rfc2 = RandomForestClassifier(n_estimators=100, max_depth=5)
rfc2.fit(X_train, y_train)
print("Training set score: {:.2f}".format(rfc2.score(X_train, y_train)))
print("Testing set score: {:.2f}".format(rfc2.score(X_test, y_test)))

# 预测标签
pred = lr.predict(X_train)
# 此时我们可以看到0和1的数组
pred[:10]
# 预测标签概率
pred_proba = lr.predict_proba(X_train)
pred_proba[:10]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 安装K210 SDK 首先需要下载K210 SDK,官方提供了两种方式下载: (1)从Github上下载:https://github.com/kendryte/kendryte-standalone-sdk (2)从Gitee上下载:https://gitee.com/kendryte/kendryte-standalone-sdk 下载完成后,解压缩到本地目录。 2. 安装Python环境 在K210 SDK中,提供了Python接口,因此需要安装Python环境。可以从Python官网下载安装包进行安装。 3. 安装Keras和TensorFlow Keras是一个高级的神经网络API,基于TensorFlow框架实现。因此,需要安装Keras和TensorFlow。 在命令行中输入以下指令: ``` pip install keras pip install tensorflow ``` 4. 编写神经网络模型 在本地目录中,创建一个新的Python文件,命名为“model.py”。在该文件中,编写神经网络模型。 例如,可以编写一个基于卷积神经网络的模型: ``` from keras.models import Sequential from keras.layers import Conv2D, MaxPooling2D, Dense, Flatten model = Sequential() model.add(Conv2D(32, (3, 3), activation='relu', input_shape=(28, 28, 1))) model.add(MaxPooling2D((2, 2))) model.add(Conv2D(64, (3, 3), activation='relu')) model.add(MaxPooling2D((2, 2))) model.add(Conv2D(64, (3, 3), activation='relu')) model.add(Flatten()) model.add(Dense(64, activation='relu')) model.add(Dense(10, activation='softmax')) model.summary() ``` 该模型包括三个卷积层、两个池化层和两个全连接层。 5. 训练神经网络模型 在本地目录中,创建一个新的Python文件,命名为“train.py”。在该文件中,读取数据集、编译模型、训练模型。 例如,可以编写以下代码: ``` from keras.datasets import mnist from keras.utils import to_categorical from model import * (train_images, train_labels), (test_images, test_labels) = mnist.load_data() train_images = train_images.reshape((60000, 28, 28, 1)) train_images = train_images.astype('float32') / 255 test_images = test_images.reshape((10000, 28, 28, 1)) test_images = test_images.astype('float32') / 255 train_labels = to_categorical(train_labels) test_labels = to_categorical(test_labels) model.compile(optimizer='rmsprop', loss='categorical_crossentropy', metrics=['accuracy']) model.fit(train_images, train_labels, epochs=5, batch_size=64) test_loss, test_acc = model.evaluate(test_images, test_labels) print('Test accuracy:', test_acc) ``` 该代码中,从Keras下载MNIST数据集,将数据集分为训练集和测试集,对数据进行预处理,编译模型,训练模型,评估模型。 6. 导出模型 在训练完成后,可以将模型导出到K210 SDK中。在“train.py”文件中,添加以下代码: ``` model.save('model.h5') ``` 该代码将训练好的模型保存为“model.h5”文件。 7. 在K210 SDK中加载模型 在K210 SDK中,可以使用MaixPy脚本加载模型进行推理。例如,可以编写以下代码: ``` import sensor import image import lcd import KPU as kpu lcd.init() sensor.reset() sensor.set_pixformat(sensor.RGB565) sensor.set_framesize(sensor.QVGA) sensor.run(1) task = kpu.load(0x300000) kpu.set_outputs(task, 0, 1, 1, 10) while True: img = sensor.snapshot() img = img.resize(28, 28) img = img.to_grayscale() img = img.strech_char(1, 99) img = img.invert() img = img.to_bytes() out = kpu.forward(task, img) print(out) ``` 该代码中,使用MaixPy库从摄像头中读取图像,对图像进行预处理,使用KPU库加载模型,将图像输入模型进行推理,输出结果。 8. 运行代码 在K210 SDK中,编译并下载代码。将K210开发板连接到计算机,打开串口监视器,运行代码。当摄像头中出现手写数字时,将进行推理并输出结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值