java lr_逻辑回归(LR)算法java实现

按照机器学习实战的python代码,用java重写LR的梯度上升算法:package com.log;import java.io.BufferedReader;import java.io.FileInputStream;import java.io.InputStreamReader;import java.io.File;import java.util.ArrayList;import java.util.Iterator;import Jama.Matrix;public class LogProcess {/*** 获取特征数据*/public Matrix getDataMat(){try {ArrayList list = new ArrayList();String pathname = "C:\\testSet.txt";File filename = new File(pathname);InputStreamReader reader = new InputStreamReader(new FileInputStream(filename));BufferedReader br = new BufferedReader(reader);String line = "";line = br.readLine();while (line != null) {String [] tmp=line.split("\t");double [] value=new double[3];value[0]=1.0;value[1]=Double.parseDouble(tmp[0]);value[2]=Double.parseDouble(tmp[1]);list.add(value);line = br.readLine(); // 一次读入一行数据}//特征转化为二维数组Iterator datalIt = list.iterator();double [][] data = new double[list.size()][3];int i=0;while (datalIt.hasNext()) {double [] tmp = datalIt.next();data[i][0]=tmp[0];data[i][1]=tmp[1];data[i][2]=tmp[2];i++;}Matrix dataMatrix = new Matrix(data);return dataMatrix;} catch (Exception e) {e.printStackTrace();return null;}}/*** 获取标签数据*/public Matrix getLabelMat(){try {ArrayList list = new ArrayList();String pathname = "C:\\testSet.txt";File filename = new File(pathname);InputStreamReader reader = new InputStreamReader(new FileInputStream(filename));BufferedReader br = new BufferedReader(reader);String line = "";line = br.readLine();while (line != null) {String [] tmp=line.split("\t");int [] value=new int[1];value[0]=Integer.parseInt(tmp[2]);list.add(value);line = br.readLine(); // 一次读入一行数据}//将标签转化为二维数组Iterator labelIt = list.iterator();double [][] label = new double[list.size()][1];int j=0;while (labelIt.hasNext()) {label[j][0]=labelIt.next()[0];j++;}Matrix labelMatrix = new Matrix(label);return labelMatrix;} catch (Exception e) {e.printStackTrace();return null;}}/*** sigmoid函数*/public Matrix sigmoid(Matrix intX){double [][] tmp = new double[intX.getRowDimension()][intX.getColumnDimension()];for(int i=0;i

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值