B555 Programming Project 3 solved

$35.00

Category: You will Instantly receive a download link for .zip solution file upon Payment || To Order Original Work Click Custom Order?

Description

5/5 - (8 votes)

Data
Data for this assignment is provided in a zip file pp3data.zip on Canvas. Each dataset is given
in two files with the data in one and the labels in the other file. We will use the datasets A and
usps for classification with logistic regression. We will use the dataset AP for count prediction with
Poisson regression. We will use the dataset AO for ordinal prediction with ordinal regression.
The datasets A, AP, AO were artificially generated with labels which are not perfectly matched
to any linear predictor yet they are generated to be somewhat predictable. The examples in usps
represent 16×16 bitmaps of the characters 3 and 5 and are taken from the well known usps dataset
(representing data originally used for zip code classification).
Implementing our variant of GLM
In this assignment we will use a Bayesian (or regularized) version of the algorithm with w ∼
N (0,
1
α
I), where α = 10, to calculate the MAP solution wMAP .
• As discussed in class logistic regression (and by extension GLM) relies on a free parameter
(w0) to capture an appropriate separating hyperplane. Therefore, you will need to add a
feature fixed at one (also known as an intercept) to all datasets in the assignment. To match
the test case below please add this as the first column in the data matrix.
• The vector of first derivatives of the log posterior is g =
∂LogL
∂w =
P
i diφ(xi)−αw = ΦT d−αw
where d is a vector whose elements are di
.
1
• The matrix of second derivatives of the log posterior is H =
∂LogL
∂w∂wT = −
P
i
riφ(xi)φ(xi)
T −
αI = −Φ
T RΦ − αI where R is a matrix with elements ri on the diagonal.
• The GLM algorithm initializes the weight vector as w = 0 and then repeatedly applies an
update with Netwon’s method w ← w − H−1
g until w converges.
• For this assignment we consider that w has converged if kwn+1−wnk2
kwnk2
< 10−3 where wn, wn+1
are the values of w before and after the update respectively. If w has not converged in 100
iterations we stop and output the last w as our solution.
• The final vector, when the algorithm stops is wMAP . In this assignment we will use wMAP
for prediction (i.e. we will not calculate a predictive distribution).
Likelihood models
• In order to apply the algorithm for any likelihood model and to evaluate its predictions we
need to specify 4 items: (1) di
, (2) ri
, (3) how to compute our prediction tˆ for test example
z, and (4) how to calculate the error when we predict tˆ and the true label is t.
• For the logistic likelihood we have: yi = σ(w
T φ(xi)) and the first derivative term is di = ti−yi
or d = t − y. The second derivative term is ri = yi(1 − yi). For test example z we predict
t = 1 iff p(t = 1) = σ(w
T
MAP φ(z)) ≥ 0.5. The error is 1 if tˆ6= t.
• Note that for the logistic model the update formula as developed in class is wn+1 ← wn −
(−αI − Φ
T RΦ)−1
[ΦT
(t − y) − αwn]. You might want to start developing your code and
testing it with this special case and then generalize it to handle all likelihoods. To help you
test your implementation of this algorithm we provide an additional dataset, irlstest, and
solution weight vector in irlsw. The first entry in irlsw corresponds to w0.
• For the Poisson likelihood we have: yi = e
(wT φ(xi)) and the first derivative term is di = ti−yi or
d = t−y. The second derivative term is ri = yi
. For test example z we have p(t) = P oisson(λ)
where a = w
T
MAP φ(z) and λ = e
a
. We predict with the mode t = bλc, the nearest integer
≤ λ. For this assignment we will use the absolute error: err = |tˆ− t|.
• For the ordinal model with K levels we have parameters s and φ0 = −∞ < φ1 < . . . <
φK−1 < φK = ∞ where for this assignment we will use K = 5, s = 1 and φ0 = −∞ < φ1 =
−2 < φ2 = −1 < φ3 = 0 < φ4 = 1 < φ5 = ∞. The model is somewhat sensitive to the setting
of hyperparameters so it is important to use these settings.
Here ai = w
T φ(xi) and for j ∈ {0, . . . K} we have yi,j = σ(s ∗ (φj − ai)). Using this notation,
for example i with label ti we have di = yi,ti + yi,(ti−1) − 1. For the second derivative we have
ri = s
2
[yi,ti
(1 − yi,ti
) + yi,(ti−1)(1 − yi,(ti−1))].
To predict for test example z we first calculate the y values: a = w
T
MAP φ(z) and for j ∈
{0, . . . K} we have yj = σ(s ∗ (φj − a)). Then for potential labels j ∈ {1, . . . K} we calculate
pj = yj − yj−1. Finally select tˆ = argmaxj pj . For this assignment we will use the absolute
error, or the number of levels we are off in prediction, that is, err = |tˆ− t|.
2
Implementation and Evaluation of the Algorithms
The main idea in GLM is to build a generic implementation that in principle can handle any
likelihood model. Accordingly you should provide one implementation of the optimization and
evaluation process which makes use of functions that compute the 4 items described in the last
section. You can then call this implementation on each likelihood model to obtain results.
Your task is to implement the GLM algorithm and generate learning curves with error bars (i.e.,
±1σ) as follows.
Repeat 30 times
Step 1) Set aside 1/3 of the total data (randomly selected) to use as a test set.
Step 2) Permute the remaining data and record the test set error rate as a function of increasing
training set portion (0.1,0.2, . . . ,1 of the total size).
Calculate the mean and standard deviation for each size and plot the result. In addition record the
number of iterations and the run time untill convergence in each run and report their averages.
In your submission provide 4 plots, one for each dataset, and corresponding runtime/iterations
statistics, and provide a short discussion of the results. Are the learning curves as expected? how
does learning time vary across datasets for classification? and across the likelihood models? what
are the main costs affecting these (time per iteration, number of iterations)?
Extra Credit
Explore some approach for model selection for α in all models and/or for s and φ in the ordinal
model and report your results. You may want to generate your own data with known parameters
in order to test the success of algorithms in identifying good parameters.
Submission
Please submit two separate items via Canvas:
(1) A zip file pp3.zip with all your work and the report. The zip file should include: (1a) Please
write a report on the experiments, include all plots and results, and your conclusions as requested
above. Prepare a PDF file with this report. (1b) Your code for the assignment, including a
README file that explains how to run it. When run your code should produce all the results and
plots as requested above. Your code should assume that the data files will have names as specified
above and will reside in sub-directory pp3data/ of the directory where the code is executed. We
will read your code as part of the grading – please make sure the code is well structured and easy
to follow (i.e., document it as needed). This portion can be a single file or multiple files.
(2) One PDF “printout” of all contents in 1a,1b: call this YourName-pp3-everything.pdf. One
PDF file which includes the report, a printout of the code and the README file. We will use
this file as a primary point for reading your submission and providing feedback so please include
anything pertinent here.
3
Grading
Your assignment will be graded based on (1) the clarity of the code, (2) its correctness, (3) the
presentation and discussion of the results, (4) our ability to run the code on SICE servers.
4