-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathcars.js
81 lines (72 loc) · 2.39 KB
/
cars.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
// The data used for this example was pulled from
// http://archive.ics.uci.edu/ml/datasets/Automobile
var csvParse = require('csv-parse'),
fs = require('fs'),
LinearRegression = require('../index').LinearRegression,
_ = require('underscore');
var apiKey = process.env.PLOTLY_API_KEY;
var username = process.env.PLOTLY_USERNAME;
var plotly = require('plotly')(username,apiKey);
fs.readFile('./examples/cars.data', 'utf8', function(err, dataStr) {
if (err) {
console.log(err);
process.exit(1);
}
csvParse(dataStr, {delimiter: ',', auto_parse: true}, function(err, data) {
// First, clean up the training data by eliminating rows that have invalid values
var cleanData = _.filter(data, function(d) { return typeof d[0] === 'number' && typeof d[1] === 'number'; });
// We are only going two columns:
// x: horsepower
// y: price of car
var x = cleanData.map(function(h) { return h[21]; }); // x is horsepower
var y = cleanData.map(function(h) { return h[25]; }); // y is price
// Initialize and train the linear regression
var lr = new LinearRegression(x, y);
lr.train(function(err) {
if (err) {
console.log('error', err);
process.exit(2);
}
// Use the linear regression function to get a set of data to graph the linear regression line
var y2 = [];
x.forEach(function(xi) {
y2.push(lr.predict(xi));
});
// Create scatter plots of training data + linear regression function
var layout = {
title: 'Car Prices vs Horsepower',
xaxis: {
title: 'Horsepower'
},
yaxis: {
title: 'Price in $'
}
};
var trace1 = {
x: x,
y: y,
name: 'Training Data',
mode: "markers",
type: "scatter"
};
var trace2 = {
x: x,
y: y2,
name: 'Linear Regression',
mode: "lines",
type: "scatter"
};
var plotData = [trace1, trace2];
var graphOptions = {layout: layout,filename: "cars-linear-regression-with-shaman", fileopt: "overwrite"}
plotly.plot(plotData, graphOptions, function (err, msg) {
if (err) {
console.log(err);
process.exit(3);
} else {
console.log('Success! The plot (' + msg.filename + ') can be found at ' + msg.url);
process.exit();
}
});
});
});
});