-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex2.html
161 lines (153 loc) · 12.8 KB
/
index2.html
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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/js/bootstrap.min.js"></script>
<script src="https://cdn.plot.ly/plotly-latest.min.js"></script>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>US Unemployment Rates</title>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<link rel="stylesheet" href="static/css/style.css">
</head>
<body>
<div class="container">
<div class="row">
<div class="col-md-12 jumbotron text-center">
<h1 class="display-4"><font color="black">Unemployment Prediction of 2022</font></h1>
<p><font color="white">Use the drop down tabs below to explore the process</font></p>
</div>
</div>
<div class="container d-grid gap-3">
<div class="col-md-8 mx-auto p-2 bg-light border">
<span class="align-middle">
<font color="white"><h3>What will the unemployment rates for the United States look like in December 2022?</h3>
<p>
With the use of a forecasting machine learning model, data from two sources (Bureau of Labor Statistics and Federal Reserve Bank of St. Louis) was ran through the model to help predict what the unemployment rate will be in December of 2022 or the next month, April 2021. Using the drop down tabs below, you may look through the steps taken by the team to better understand the process of predicting unemployment rates within the United States.
</p></font>
</span>
</div>
</div>
</div>
<div class="panel-group" id="accordion" role="tablist" aria-multiselectable="true">
<div class="panel panel-default">
<div class="panel-heading" role="tab" id="headingOne">
<h4 class="panel-title">
<a role="button" data-toggle="collapse" data-parent="#accordion" href="#collapseOne" aria-expanded="true" aria-controls="collapseOne">
Initial Data
</a>
</h4>
</div>
<div id="collapseOne" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingOne">
<div class="panel-body">
<p align="left">The historical data that was collected for this project comes from two sources: the Bureau of Labor Statistics (BLS) and The Federal Reserve Bank of St. Louis' Federal Reserve Economic Database (FRED). These two sources provided the foundation of the beginning of the predictions. Some of the categories being used in the predicitions are the historical unemployment rates from 2000 to 2021 recorded by race, gender, and education as seen below. This collected data was scraped from the websites using API keys and placed into a PostgreSQL database once cleaned. This process allowed for the data to be properly used in the following machine learning models.</p>
<div class="col-md-5">
<div id="gender"></div>
</div>
<div class="col-md-5">
<div id="education"></div>
</div>
<div class="col-md-5">
<div id="race"></div>
</div>
<div class="col-md-5">
<div id="national"></div>
</div>
</div>
</div>
</div>
<div class="panel panel-default">
<div class="panel-heading" role="tab" id="headingTwo">
<h4 class="panel-title">
<a class="collapsed" role="button" data-toggle="collapse" data-parent="#accordion" href="#collapseTwo" aria-expanded="false" aria-controls="collapseTwo">
The Database
</a>
</h4>
</div>
<div id="collapseTwo" class="panel-collapse collapse" role="tabpanel" aria-labelledby="headingTwo">
<div class="panel-body">
<p align="left">Before the data could be used in the models, it needed to be stored in a location that all members could access. The best solution was the cloud storage feature from Amazon, AWS RDS cloud database. Within that cloud storage, an S3 bucket was used to house the cleaned CSV files. From there, the team connected the S3 bucket to a local PostgreSQL database. Queries were used to combine tables of data in order to have data sets that could be run through the machine learning models tested by the team. The files stored in the S3 bucket and pgAdmin were easily accessed using Google Colab and PySpark to review the cleaned and sorted data prior to testing.
</p>
<img src="/Graphs/s3bucket.png" alt="AWS Bucket">
<img src="/Graphs/postgresquery.png" alt="Postgres Query">
<img src="/Graphs/pysparkwrite.png" alt="PySpark">
</div>
</div>
</div>
<div class="panel panel-default">
<div class="panel-heading" role="tab" id="headingThree">
<h4 class="panel-title">
<a class="collapsed" role="button" data-toggle="collapse" data-parent="#accordion" href="#collapseThree" aria-expanded="false" aria-controls="collapseThree">
The First Machine Learning Model - KNN
</a>
</h4>
</div>
<div id="collapseThree" class="panel-collapse collapse" role="tabpanel" aria-labelledby="headingTwo">
<div class="panel-body">
<p align="left">With data that is continuous, it was important to utilize machine learning methods that would provide numerical results. The first model implemented was the K-Nearest Neighbor (KNN) algorithm. This particular model can be used for either linear regression or classification, however, for this prediction project the focus was on linear regression. The data collected from the API calls was split into training and testing sets to test the accuracy of the model. The first test with this model, as seen below, was using data from 2001 to attempt to predict the rates from 2002 in order to test the accuracy. It was discovered that the model was overfitting and could not predict future dates with the accuracy the project needed.
</p>
<img src="/Graphs/KNN.png" alt="KNN Model Sample">
</div>
</div>
</div>
<div class="panel panel-default">
<div class="panel-heading" role="tab" id="headingFour">
<h4 class="panel-title">
<a class="collapsed" role="button" data-toggle="collapse" data-parent="#accordion" href="#collapseFour" aria-expanded="false" aria-controls="collapseFour">
The Second Machine Learning Model - SVR
</a>
</h4>
</div>
<div id="collapseFour" class="panel-collapse collapse" role="tabpanel" aria-labelledby="headingFour">
<div class="panel-body">
<p align="left">Another approach the team decided to take was using the machine learning mdelo known as Support Vector Regression (SVR). This particular method focuses on producing discrete value predictions. With the goal of predicting unemployment rates, discrete values are ideal and the most useful for the scope of the project. The initial dataset used to test and train the SVR model was sourced from an API scrape containing multiple features in hopes to gain the best outcome. This approach seemed to work and provide positive outcomes. However, the results could not be replicated any time after. The team decided it was best to move one from this method and try the third machine learning model.
</p>
<img src="/Graphs/graphpy.png" alt="API Scrape">
</div>
</div>
</div>
<div class="panel panel-default">
<div class="panel-heading" role="tab" id="headingFive">
<h4 class="panel-title">
<a class="collapsed" role="button" data-toggle="collapse" data-parent="#accordion" href="#collapseFive" aria-expanded="false" aria-controls="collapseFive">
The Third Machine Learning Model - ARIMA
</a>
</h4>
</div>
<div id="collapseFive" class="panel-collapse collapse" role="tabpanel" aria-labelledby="headingFive">
<div class="panel-body">
<p align="left">Once it was decided that the first model, KNN, would not create an accurate predicition, a new method was selected. The next model explored was AutoRegressive Integrated Moving Average (ARIMA). This particular model utilizes a type of time series forecasting model. Forecasting is a popuilar machine learning method to use when predicting the future values the series in question will take. A time series can be of a yearly, quarterly, monthly, weekly, daily, hourly, minutes, and seconds frequency. With unemployment rates being recorded monthly and yearly by most reporting agencies, this particular model best fits the current data sets available in structure. This particular type of machine learning also requires that data be stationary for best results when performing testing and training. The overall unemployment rates CSV file was used as the sample data for three main tests of the ARIMA method. In the initial test, it was found that the unemployment rates provided for the next twelve months were suspiciously high, ranging from six to seventeen percent. It is suspected that the team did not have a full understanding of the machine learning method to make appropriate adjustments. The second attempt was created following similar methods for predicting temperature, however, the model provided a consisent result of 6.7% for every month. When adjustments were made, the unemployment prediction produced was stationary at 3.9%. This percentage rate was in line with the historical data. However, the second test of the ARIMA model did not provide variation in results which leaves the team to believe that the model was not successful despite being within range of acceptable results and creating accurate testing and training scores. The final attempt using the ARIMA model could not be moved past the training and testing phase as it did not produce future predictions like the previous two attempts. Overall, the model seemed extremely promising based on the research performed, but did not meet the team's standards and expectations.
</p>
<img src="/Graphs/Arima_Test_1_Results.png" alt="ARIMA Model Sample">
<img src="/Graphs/arimatest2predplot.png" alt="ARIMA 2 Prediction Plot">
<img src="/Graphs/arimatest2futurepred.png" alt="ARIMA 2 Future Prediction">
<img src="/Graphs/arimatest3.png" alt="ARIMA 3">
</div>
</div>
</div>
<div class="panel panel-default">
<div class="panel-heading" role="tab" id="headingSix">
<h4 class="panel-title">
<a class="collapsed" role="button" data-toggle="collapse" data-parent="#accordion" href="#collapseSix" aria-expanded="false" aria-controls="collapseSix">
The Results
</a>
</h4>
</div>
<div id="collapseSix" class="panel-collapse collapse" role="tabpanel" aria-labelledby="headingSix">
<div class="panel-body">
<p align="left">After completing an exploration of the KNN and ARIMA machine learning models, it was discovered that both models had their pros and cons. The ARIMA model best fit the goals of the project itself. The model was built to predict similar concepts built around time frequencies. Yet, when the model was put through testing and training, the results proved too high or simply predicting the same percentage continuously. The KNN model on the other hand, did not have the same issues with predicting future unemployment rates. Testing the model proved to show a high accuracy. This high accuracy was a concern of being overfitting based on the single CSV file that was used for sample data. In both cases, more time and further research would provide a clearer picture of which model could accurately predict future unemployment rate in the United States based on a multitude of factors.
</p>
<div class="col-md-5">
<div id="arima"></div>
</div>
</div>
</div>
</div>
</div>
<script src="static/js/gender.js"></script>
</body>
</html>