常见machine learning模型实现
一、感知机模型
二、线性回归(Linear Regression)
- from numpy import *
- def loadData(filename):
- x = []
- y = []
- f = open(filename)
- for line in f.readlines():
- lineData = line.strip().split(',')
- x.append([1.0,float(lineData[0])])
- y.append(float(lineData[1]))
- return x,y
- #预测函数,theta,x都是一维数组,dot运算得到实数,对于二维数组,dot运算就是矩阵运算
- def h(theta,x):
- return theta.dot(x)
- #批量梯度下降
- def batch_gradient_descent(alpha,theta,x,y):
- m,n = x.shape
- newtheta = array([0] * n,dtype = float)
- for j in range(n):
- count = 0.0
- for i in range(m):
- count += (h(theta,x[i,:]) - y[i])*x[i,j]
- newtheta[j] = newtheta[j] - count * alpha / m
- return newtheta
- #正则方程
- def normal_equation(x,y):
- return linalg.inv(transpose(x).dot(x)).dot(transpose(x)).dot(y)
- #损失函数
- def cost_function(theta,x,y):
- m = x.shape[0]
- return (x.dot(theta) - y).dot(x.dot(theta) - y) / (2 * m)
- def run():
- x,y = loadData('ex1data1.txt')
- x = array(x)
- y = array(y) #列向量
- m,n = x.shape
- theta = array([0] * n,dtype = float)
- costs = []
- for iters in range(1000):
- costs.append(cost_function(theta,x,y))
- theta = batch_gradient_descent(0.01,theta,x,y)
- print "batch gradient descent:\n"
- print "theta:",theta
- print 'cost:\n',costs
- print "normal equation:\n"
- theta = normal_equation(x,y)
- print "theta:",theta
- if __name__ == "__main__":
- run()
三、Logistic Regression
- def sigmoid(x):
- return 1.0/(1 + exp(-x))
- def trainLogRegres(x,y,opts):
- m,n = x.shape
- alpha = opts["alpha"]
- maxIter = opts['maxIter']
- weight = ones((n,1))
- for k in range(maxIter):
- if opts['optimizeType'] == 'batchGraDescent':
- weight = weight - alpha * x.T * (sigmoid(x*weight) - y)
- elif opts['optimizeType'] == 'stocGraDescent':
- for i in range(m):
- weight = weight - alpha * x[i,:].T * (sigmoid(x[i,:] * weight) - y[i,0])
- else:
- raise NameError('Not support optimize method type!')
- return weight
- def testLogRegres(weight,x,y):
- m,n = x.shape
- trueNum = 0
- for i in range(m):
- predict = sigmoid(x[i,:] * weight)[0,0] > 0.5
- if predict == bool(y[i,0]):
- trueNum += 1
- accuracy = float(trueNum) / m
- return accuracy
- #x每行对应一个样本,y是列向量
- def loadData():
- x = []
- y = []
- f = open("testSet.txt")
- for line in f.readlines():
- lineArr = line.strip().split()
- x.append([1.0, float(lineArr[0]), float(lineArr[1])])
- y.append(float(lineArr[2]))
- return mat(x),mat(y).T
- if __name__ == '__main__':
- x,y = loadData()
- opts = {'alpha': 0.01, 'maxIter': 50, 'optimizeType': 'stocGraDescent'}
- weight = trainLogRegres(x,y,opts)
- accuracy = testLogRegres(weight,x,y)
- print "accuracy:",accuracy
四、SVM
五、kmeans
https://en.wikipedia.org/wiki/Latent_semantic_analysis
常见machine learning模型实现的更多相关文章
- 机器学习---最小二乘线性回归模型的5个基本假设(Machine Learning Least Squares Linear Regression Assumptions)
在之前的文章<机器学习---线性回归(Machine Learning Linear Regression)>中说到,使用最小二乘回归模型需要满足一些假设条件.但是这些假设条件却往往是人们 ...
- 【Machine Learning】KNN算法虹膜图片识别
K-近邻算法虹膜图片识别实战 作者:白宁超 2017年1月3日18:26:33 摘要:随着机器学习和深度学习的热潮,各种图书层出不穷.然而多数是基础理论知识介绍,缺乏实现的深入理解.本系列文章是作者结 ...
- 【机器学习Machine Learning】资料大全
昨天总结了深度学习的资料,今天把机器学习的资料也总结一下(友情提示:有些网站需要"科学上网"^_^) 推荐几本好书: 1.Pattern Recognition and Machi ...
- Machine Learning Algorithms Study Notes(4)—无监督学习(unsupervised learning)
1 Unsupervised Learning 1.1 k-means clustering algorithm 1.1.1 算法思想 1.1.2 k-means的不足之处 1 ...
- Machine Learning Algorithms Study Notes(2)--Supervised Learning
Machine Learning Algorithms Study Notes 高雪松 @雪松Cedro Microsoft MVP 本系列文章是Andrew Ng 在斯坦福的机器学习课程 CS 22 ...
- 机器学习(Machine Learning)&深度学习(Deep Learning)资料
<Brief History of Machine Learning> 介绍:这是一篇介绍机器学习历史的文章,介绍很全面,从感知机.神经网络.决策树.SVM.Adaboost到随机森林.D ...
- FAQ: Machine Learning: What and How
What: 就是将统计学算法作为理论,计算机作为工具,解决问题.statistic Algorithm. How: 如何成为菜鸟一枚? http://www.quora.com/How-can-a-b ...
- 机器学习(Machine Learning)&深入学习(Deep Learning)资料
<Brief History of Machine Learning> 介绍:这是一篇介绍机器学习历史的文章,介绍很全面,从感知机.神经网络.决策树.SVM.Adaboost 到随机森林. ...
- Machine Learning - 第6周(Advice for Applying Machine Learning、Machine Learning System Design)
In Week 6, you will be learning about systematically improving your learning algorithm. The videos f ...
随机推荐
- oracle的Hint
与优化器模式相关的Hint 1 ALl_ROWS 让优化器启用CBO /*+ all_rows */ 2 first_rows(n) 让优化器启用CBO 模式,而且得到目标sql的执行计 ...
- Wikidata和SparQL简介
知识库 数据库(Database)和SQL,相信我们大部分人都非常非常熟悉.但是“知识库”可能知道的人就要相对少一些. 知识库是一个相对比较新的概念,它其实是一堆“三元组”(类似于主-谓-宾)的组合, ...
- python爬虫---从零开始(三)Requests库
1,什么是Requests库 Requests是用python语言编写,基于urllib,采用Apache2 Licensed 开源协议的HTTP库. 它比urllib更加方便,可以节约我们大量的工作 ...
- VS打开文件,解决方案资源管理器自动定位到文件位置
打开 工具-->选项-->项目和解决方案-->常规,勾选“在解决方案资源管理器中跟踪活动项”
- mac 监控文件变化并重启php
自己撸一个框架,需要监控代码变化 安装fswatch brew install fswatch shell重启PHP脚本reload.sh #!/bin/sh do ps -ef | grep php ...
- solr之windws下搭建solr服务
安装Solr 首先保证已经正确安装了Java 下载Solr,当前最新版6.1.0 Solr各个版本下载地址 Solr从6.0之后需要Java1.8所以如果使用Solr6.0及其以上版本,请确保Java ...
- 激活windows10(已更新工具)
激活windows10 1.用cmd命令: 自己动手,KMS激活win10 2016 长期服务版.步骤如下:命令提示符(管理员),依次输入以下3条命令 slmgr /ipk DCPHK-NFMTC-H ...
- ArrayList练习之存储字符串并遍历
在myArrayList项目下 新建一个包 在这个包中新建一个类:ArrayListDemo4.java ArrayListDemo4.java import java.util.ArrayList; ...
- Druid连接池简单配置
Druid是阿里巴巴开源平台上的一个项目,整个项目由数据库连接池.插件框架和SQL解析器组成.该项目主要是为了扩展JDBC的一些限制,可以让程序员实现一些特殊的需求,比如向密钥服务请求凭证.统计SQL ...
- Apache手册
一.apache的安装 如果不指定安装位置,默认为/usr/local/apache2/