联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> Algorithm 算法作业Algorithm 算法作业

日期:2020-04-16 11:14

ECOM151: Big Data Applications in Finance

Individual Assignment

Vimal Balasubramaniam

25 February 2020

Details

Grading: 20% of your final grade.

Deadline: 31 March, 2020. Time: 22:00hrs.

Submission mode: QMplus

Submission files: 1) An assignment results.R file, and 2) A “Prediction Report” with maximum of

5-pages with the interpretation of your results.

Please refrain from copying code from each other. Your code and output submission will provide

us sufficient information to detect such practices and it will be penalized.

What am I grading you on?

I am looking to test your ability to use models learned during the first half of the course to both

apply it to real data and to synthesize insights into a report.

This assignment requires you to apply all the skills learned during your first half of the term,

and the models learned during the lectures. Your ability to estimate the model is only half of the

challenge. Your interpretation of the findings matter equally.

1

Can I ask assignment related questions during office hours?

The questions that your TA and I will answer are only to clarify the meaning of a question. We

will not provide any clue on whether what you are doing is “right”, or “wrong”, or suggest ways to

improve your code. However, if you have doubts on estimating a model, we then ask you to phrase

your questions on the tutorial datasets and models, so that we are able to provide guidance.

The dataset provided to you should not have many challenges to resolve before you estimate a

model. However, if you face any challenges while using the data on Rstudio.cloud, do reach out to

us. I strongly recommend that you work on your assignment in your computer, and not on the cloud

so that you have complete control over the file. Any excuses that the file was not “saved”, or went

“missing” on the cloud will not be entertained.

Submission files

You are expected to create an R file as part of your submission. The R file should be selfcontained,

i.e., I should be able to run the code on my computer loading the same datafile without

any error.

In addition to all your code, you are expected to store your answers in objects named as

specifically instructed in each question. The name of object is provided in blue colour next to each

question. All “R objects” or columns in objects will also be referred in blue in the text below.

In addition to the R code, you are expected to create a PDF submission of no more than 5 pages,

that present your evaluation of the models.

The Assignment

LendingClub is an American peer-to-peer lending company, currently the world’s largest

platform that allows for individuals to both invest and borrow on the platform. Borrowers can obtain

unsecured personal loans from the platform, and this assignment is set up for you to assess your

ability to predict defaulters in the data using the predictors provided in the data.

The data is a random sample of loans issued on the platform between 2007−2015, including

2

the loan status, and payment information. The data also contains a number of predictors that have

been documented in the variables description file provided to you named “ECOM151-AssignmentVariableDescription.xlsx”.

For tractability, your assignment focuses only on a small set of variables

available for prediction.

You have been provided with on RData file named “ECOM151-Assignment-Data.rda” that

contain three objects:

trainData: This is the dataset on which you will train all your models.

testData: This is the dataset on which you will evaluate your model’s fit.

varDescription: This is a replication of the variable description available in the excel spreadsheet

provided to you.

Question A (10 points)

This question expects you to estimate five different class of models to identify the best model to

predict default on the LendingClub platform.

Set up the data

Load the RData file provided to you on to your work environment.

Questions:

1. Create a new variable in trainData called “y” which takes the value = 1 if loan status is

“Charged Off” and 0 otherwise.

2. All variables provided to you other than loan status are referred to as “predictors”.

3. Find the top 10 positively correlated variables with y and store it as a4.

4. Find the top 10 negatively correlated variables with y and store it as a5.

Now, we are ready to run the five models of interest. Spend time, and visualize the data. Inspect

for potential reasons why the model may not be estimated.

3

Pay particular attention to whether you would like to transform your variables (For example, a

logarithmic transformation). This may also help with interpretting coefficients in your “Prediction

Report”.

You may also want to consider converting some of the categorical variables (for example,

emp length) into a continuous variable.

6. LINEAR REGRESSION MODEL: Fit a linear regression model to the trainData, with y as the

outcome variable, with the predictors.

(a) What is the Mean squared error for the training data? Store this value in object named

m1.1.

(b) What is the Mean squared error for the testing data? Store this value in object named

m1.2.

7. BEST SUBSET MODEL: Fit a “Best subset selection” model to the trainData, with y as the

outcome variable, with the predictors.

Explore all approaches: “forward”, “backward”, and “unconstrained” best subset. Note that it

may take some time to execute the model in R, and with all of the predictors.

(a) What is the Mean squared error for the “best” model of this class for the training data?

Store this value in object named m2.1.

(b) What is the Mean squared error for the “best” model of this class for the test data? Store

this value in object named m2.2.

(c) What are the variables in the “best” model of this class? Store this in object named

m2.3.

8. RIDGE REGRESSION MODEL: Fit a ridge regression model to the trainData, with y as the

outcome variable, with the predictors.

4

Explore all values of lambda ( 1010 to 10−2

), setting alpha = 0, as in the tutorials. Hint:

glmnet() cannot handle “factor” or categorical variables. You will have to convert them into

dummies to be used.

(a) What is the Mean squared error for the “best” model of this class for the training data?

Store this value in object named m3.1.

(b) What is the Mean squared error for the “best” model of this class for the test data? Store

this value in object named m3.2.

(c) What are the 10 most important variables in the “best” model of this class? Store this in

object named m3.3.

9. LASSO: Fit a LASSO to the trainData, with y as the outcome variable, with the predictors.

Explore all values of lambda, setting the alpha parameter to 1 (the lasso penalty) in glmnet().

Hint: glmnet() cannot handle “factor” or categorical variables. You will have to convert them

into dummies to be used.

(a) What is the Mean squared error for the “best” model of this class for the training data?

Store this value in object named m4.1.

(b) What is the Mean squared error for the “best” model of this class for the test data? Store

this value in object named m4.2.

(c) What are the 10 most important variables in the “best” model of this class? Store this in

object named m4.3.

10. RANDOMFOREST: Fit a randomForest to the trainData, with y as the outcome variable, with

the predictors.

Explore and fit the best model of this class. Hint: randomForest() cannot handle “factor” or

categorical variables. You will have to convert them into dummies to be used.

5

(a) What is the Mean squared error for the “best” model of this class for the training data?

Store this value in object named m5.1.

(b) What is the Mean squared error for the “best” model of this class for the test data? Store

this value in object named m5.2.

(c) How important are the variables in predicting default? Store this value in object named

m5.3.

11. Compare and contrast the predictive power of all approaches and identify the best model to

predict default in the LendingClub data. Store this model in object named finalModel.

Question B (10 points)

You are required to synthesize all the work in Question A to submit a “Prediction Report” to

your manager on your ability to predict default for borrowers on the LendingClub platform. Utilize

all the information you have generated to write a report no longer than 5 pages and present your

best model to your manager. Pay attention to explain why it is the best model, in terms of its out of

sample predictive power, and visualize the model’s predictive power compared to the other models

on hand.

6


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp