2020吴恩达 machine learning 编程作业 python实现 ex3_nn

# -*- coding: utf-8 -*-
"""
Created on Wed Jul  1 20:28:57 2020

@author: cheetah023
"""
import numpy as np
import matplotlib.pyplot as plt
import scipy.io as sci
import random as ra

#函数定义
def sigmoid(X):
    return 1 /(1 + np.exp(-X))
def predict(theta1, theta2, X):
    m = X.shape[0]
    ones = np.ones([m,1])
    X = np.column_stack([ones,X])
    a2 = sigmoid(np.dot(X,theta1.T))
    a2 = np.column_stack([ones,a2])
    a3 = sigmoid(np.dot(a2,theta2.T))
    p = np.argmax(a3,axis = 1) + 1
    p = np.reshape(p,[m,1])
    return p
    
    
#Part 1: Loading and Visualizing Data
data1 = sci.loadmat('ex3data1.mat')
#print(data) #data是个字典类型
X = data1['X']
y = data1['y']
#print('X',X.shape)
#print('y',y.shape)
#Part 2: Loading Pameters
data2 = sci.loadmat('ex3weights.mat')
#print(data2.keys())
theta1 = data2['Theta1']
theta2 = data2['Theta2']
#print('theta1',theta1.shape)
#print('theta2',theta2.shape)

#Part 3: Implement Predict
p = predict(theta1, theta2, X)
#temp里面的值是True(=1)和False(=0)
temp = (p==y)
prob = np.mean(temp)
print('Training Set Accuracy:',prob)

运行结果:

Training Set Accuracy: 0.9752

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值