forked from FluxML/model-zoo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
housing.jl
56 lines (43 loc) · 1.45 KB
/
housing.jl
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
using Flux.Tracker, Statistics, DelimitedFiles
using Flux.Tracker: Params, gradient, update!
using DelimitedFiles, Statistics
using Flux: gpu
# This replicates the housing data example from the Knet.jl readme. Although we
# could have reused more of Flux (see the mnist example), the library's
# abstractions are very lightweight and don't force you into any particular
# strategy.
cd(@__DIR__)
isfile("housing.data") ||
download("https://raw.githubusercontent.com/MikeInnes/notebooks/master/housing.data",
"housing.data")
rawdata = readdlm("housing.data")'
# The last feature is our target -- the price of the house.
split_ratio = 0.1 # For the train test split
x = rawdata[1:13,:] |> gpu
y = rawdata[14:14,:] |> gpu
# Normalise the data
x = (x .- mean(x, dims = 2)) ./ std(x, dims = 2)
# Split into train and test sets
split_index = floor(Int,size(x,2)*split_ratio)
x_train = x[:,1:split_index]
y_train = y[:,1:split_index]
x_test = x[:,split_index+1:size(x,2)]
y_test = y[:,split_index+1:size(x,2)]
# The model
W = param(randn(1,13)/10) |> gpu
b = param([0.]) |> gpu
predict(x) = W*x .+ b
meansquarederror(ŷ, y) = sum((ŷ .- y).^2)/size(y, 2)
loss(x, y) = meansquarederror(predict(x), y)
η = 0.1
θ = Params([W, b])
for i = 1:10
g = gradient(() -> loss(x_train, y_train), θ)
for x in θ
update!(x, -g[x]*η)
end
@show loss(x_train, y_train)
end
# Predict the RMSE on the test set
err = meansquarederror(predict(x_test),y_test)
println(err)