forked from FluxML/model-zoo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
housing.jl
46 lines (33 loc) · 1.07 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
using Flux.Tracker, Statistics, DelimitedFiles
using Flux.Tracker: Params, gradient, update!
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.
x = rawdata[1:13,:] |> gpu
y = rawdata[14:14,:] |> gpu
# Normalise the data
x = (x .- mean(x, dims = 2)) ./ std(x, dims = 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, y), θ)
for x in θ
update!(x, -g[x]*η)
end
@show loss(x, y)
end
predict(x[:,1]) / y[1]