-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.Rmd
127 lines (78 loc) · 5.68 KB
/
index.Rmd
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
---
title: "Machine Learning in Python"
author: "Joshua G. Mausolf"
date: "November 16, 2016"
output:
html_document:
toc: true
toc_float: true
---
```{r setup, include=FALSE}
knitr::opts_chunk$set(cache=TRUE)
```
# Prerequisites:
If you have not already done so, you will need to properly install an Anaconda distribution of Python, following the installation [instructions from the first week](https://uc-cfss.github.io/setup00.html).
I would also recommend installing a friendly text editor for editing scripts such as [Atom](https://atom.io). Once installed, you can start a new script by simply typing in bash `atom name_of_your_new_script`. You can edit an existing script by using `atom name_of_script`. [SublimeText](https://www.sublimetext.com) also works similar to Atom. Alternatively, you may use a native text editor such as [Vim](https://www.linux.com/learn/vim-101-beginners-guide-vim), but this has a higher learning curve.
[*Note: If `atom` does not automatically work, try these solutions*](http://stackoverflow.com/questions/22390709/open-atom-editor-from-command-line).
**Further documentation can be found on the [tutorial README](https://github.com/jmausolf/Python_Tutorials/tree/master/Machine_Learning).**
---
#Machine Learning Tutorial
This module illustrates some basic machine learning in Python using Sci-Kit Learn.
A fundamental principal is that we do not assume *a priori* that any single model will be best for the data. Instead, we loop over multiple classifiers and parameterizations. In this way, we can run hundreds of models and select the best one on a variety of metrics, such as precision and recall.
### Example Precision-Recall Plot:
![](https://raw.githubusercontent.com/jmausolf/Python_Tutorials/master/Machine_Learning/results/example.png)
---
## Quick Start Guide
Example data for this repository comes from the [General Social Survey (GSS) 2014](http://gss.norc.org/get-the-data/stata). More notes on the data preprocessing are detailed in the [data](https://github.com/jmausolf/Python_Tutorials/tree/master/Machine_Learning/data) folder.
##### To run the example [(link to tutorial repository)](https://github.com/jmausolf/Python_Tutorials/tree/master/Machine_Learning):
```bash
git clone --recursive https://github.com/jmausolf/Python_Tutorials
cd Python_Tutorials/Machine_Learning
python run.py
```
---
## Modifying The Details
To modify the default data, outcome variable, or parameters, open the `run.py` script with your favorite text editor, such as Atom, Sublime, or Vim. Here, you must specify the dataset (as .CSV), the outcome variable you would like to predict (for binary classification), and the features you would like to use to make the predictions.
#### Default Example:
```python
#Define Data
dataset = 'file'
outcome = 'partyid_str_rep'
features = ['age', 'sex', 'race', 'educ', 'rincome']
```
Once you edit these fields, save the script, and in terminal execute: `python run.py`
#### Note:
Your data may have hundreds of features (independent variables/predictors). If you would like to use all of them (and would rather not type write them all out explicitly) simply uses the `--all_features` option of the magic loop.
```bash
python run.py --all_features True
```
Of course, an overlooked aspect thus far is feature development. The GSS data in the example is not in the ideal form. For example, most of the data is categorical. We might want to make indicators for each categorical column, calculate various aggregations or interactions, among other possibilities. An ideal data pipeline might make the changes to the feature set prior running this script.
---
## Looking Under the Hood:
To understand the in's and out's of the magic loop [(full code here)](https://github.com/jmausolf/magicloops/blob/master/magicloops.py), let's first look at a very simple example of the example data on a single model:
```python
from sklearn import metrics
from sklearn.ensemble import RandomForestClassifier
from sklearn.cross_validation import train_test_split
import pandas as pd
# Define Data
df = pd.read_csv('data/gss2014.csv', index_col=0)
outcome = 'partyid_str_rep'
features = ['age', 'sex', 'race', 'educ', 'rincome']
# Set, X, y, Train-Test Split
X, y = df[features], df[outcome]
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=0)
# Build Model and Fit
clf = RandomForestClassifier(n_estimators=10, max_depth=None,
min_samples_split=2, random_state=0)
y_pred = clf.fit(X_train, y_train).predict_proba(X_test)[:,1]
# Calculate Result
result = metrics.roc_auc_score(y_test, y_pred)
print(result)
```
Here, we are fitting a [Random Forest Model](http://scikit-learn.org/stable/modules/generated/sklearn.ensemble.RandomForestClassifier.html#sklearn.ensemble.RandomForestClassifier). Here, we set some arguments, such as `n_estimators=10`. We could have passed other parameter options such as `n_estimators=5` or `n_estimators=100`. In the magic loop, we systematically loop over a set of options for `n_estimators` and other arguments. This process is repeated for other classifiers. In this way, we can estimate hundreds of models with relative ease.
##### Now that we have covered the basics, [FORK](https://github.com/jmausolf/Python_Tutorials/blob/master/README.md#fork-destination-box) this repository and analyze your own data.
---
#### Acknowledgements
This tutorial makes use of a [modified submodule](https://github.com/jmausolf/magicloops), originally forked from @rayidghani [magicloops](https://github.com/rayidghani/magicloops). It has been updated to run in Python2 or Python3. In addition, my modified fork modifies the plotting code and several of the functions to take a user-specified dataset, outcome variable, and features.
---