Spaces:
No application file
No application file
Ayush19112
commited on
Upload 7 files
Browse files- banglore_home_prices_model.pickle +3 -0
- columns.json +1 -0
- index.html +53 -0
- script.js +62 -0
- style.css +133 -0
- tempCodeRunnerFile.py +27 -0
- util.py +48 -0
banglore_home_prices_model.pickle
ADDED
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
1 |
+
version https://git-lfs.github.com/spec/v1
|
2 |
+
oid sha256:940fcc8b7f0836360bbeba3911bce17a529f51390eaf577b64c502ee1a3cd8ca
|
3 |
+
size 8158
|
columns.json
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
{"data_columns": ["total_sqft", "bath", "bhk", "1st block jayanagar", "1st phase jp nagar", "2nd phase judicial layout", "2nd stage nagarbhavi", "5th block hbr layout", "5th phase jp nagar", "6th phase jp nagar", "7th phase jp nagar", "8th phase jp nagar", "9th phase jp nagar", "aecs layout", "abbigere", "akshaya nagar", "ambalipura", "ambedkar nagar", "amruthahalli", "anandapura", "ananth nagar", "anekal", "anjanapura", "ardendale", "arekere", "attibele", "beml layout", "btm 2nd stage", "btm layout", "babusapalaya", "badavala nagar", "balagere", "banashankari", "banashankari stage ii", "banashankari stage iii", "banashankari stage v", "banashankari stage vi", "banaswadi", "banjara layout", "bannerghatta", "bannerghatta road", "basavangudi", "basaveshwara nagar", "battarahalli", "begur", "begur road", "bellandur", "benson town", "bharathi nagar", "bhoganhalli", "billekahalli", "binny pete", "bisuvanahalli", "bommanahalli", "bommasandra", "bommasandra industrial area", "bommenahalli", "brookefield", "budigere", "cv raman nagar", "chamrajpet", "chandapura", "channasandra", "chikka tirupathi", "chikkabanavar", "chikkalasandra", "choodasandra", "cooke town", "cox town", "cunningham road", "dasanapura", "dasarahalli", "devanahalli", "devarachikkanahalli", "dodda nekkundi", "doddaballapur", "doddakallasandra", "doddathoguru", "domlur", "dommasandra", "epip zone", "electronic city", "electronic city phase ii", "electronics city phase 1", "frazer town", "gm palaya", "garudachar palya", "giri nagar", "gollarapalya hosahalli", "gottigere", "green glen layout", "gubbalala", "gunjur", "hal 2nd stage", "hbr layout", "hrbr layout", "hsr layout", "haralur road", "harlur", "hebbal", "hebbal kempapura", "hegde nagar", "hennur", "hennur road", "hoodi", "horamavu agara", "horamavu banaswadi", "hormavu", "hosa road", "hosakerehalli", "hoskote", "hosur road", "hulimavu", "isro layout", "itpl", "iblur village", "indira nagar", "jp nagar", "jakkur", "jalahalli", "jalahalli east", "jigani", "judicial layout", "kr puram", "kadubeesanahalli", "kadugodi", "kaggadasapura", "kaggalipura", "kaikondrahalli", "kalena agrahara", "kalyan nagar", "kambipura", "kammanahalli", "kammasandra", "kanakapura", "kanakpura road", "kannamangala", "karuna nagar", "kasavanhalli", "kasturi nagar", "kathriguppe", "kaval byrasandra", "kenchenahalli", "kengeri", "kengeri satellite town", "kereguddadahalli", "kodichikkanahalli", "kodigehaali", "kodigehalli", "kodihalli", "kogilu", "konanakunte", "koramangala", "kothannur", "kothanur", "kudlu", "kudlu gate", "kumaraswami layout", "kundalahalli", "lb shastri nagar", "laggere", "lakshminarayana pura", "lingadheeranahalli", "magadi road", "mahadevpura", "mahalakshmi layout", "mallasandra", "malleshpalya", "malleshwaram", "marathahalli", "margondanahalli", "marsur", "mico layout", "munnekollal", "murugeshpalya", "mysore road", "ngr layout", "nri layout", "nagarbhavi", "nagasandra", "nagavara", "nagavarapalya", "narayanapura", "neeladri nagar", "nehru nagar", "ombr layout", "old airport road", "old madras road", "padmanabhanagar", "pai layout", "panathur", "parappana agrahara", "pattandur agrahara", "poorna pragna layout", "prithvi layout", "r.t. nagar", "rachenahalli", "raja rajeshwari nagar", "rajaji nagar", "rajiv nagar", "ramagondanahalli", "ramamurthy nagar", "rayasandra", "sahakara nagar", "sanjay nagar", "sarakki nagar", "sarjapur", "sarjapur road", "sarjapura - attibele road", "sector 2 hsr layout", "sector 7 hsr layout", "seegehalli", "shampura", "shivaji nagar", "singasandra", "somasundara palya", "sompura", "sonnenahalli", "subramanyapura", "sultan palaya", "tc palaya", "talaghattapura", "thanisandra", "thigalarapalya", "thubarahalli", "thyagaraja nagar", "tindlu", "tumkur road", "ulsoor", "uttarahalli", "varthur", "varthur road", "vasanthapura", "vidyaranyapura", "vijayanagar", "vishveshwarya layout", "vishwapriya layout", "vittasandra", "whitefield", "yelachenahalli", "yelahanka", "yelahanka new town", "yelenahalli", "yeshwanthpur"]}
|
index.html
ADDED
@@ -0,0 +1,53 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
<!DOCTYPE html>
|
2 |
+
<html>
|
3 |
+
<head>
|
4 |
+
<title>Banglore Home Price Prediction</title>
|
5 |
+
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
|
6 |
+
<script src="script.js"></script>
|
7 |
+
<link rel="stylesheet" href="style.css">
|
8 |
+
</head>
|
9 |
+
<body>
|
10 |
+
<div class="img"></div>
|
11 |
+
<form class="form">
|
12 |
+
<h2>Area (Square Feet)</h2>
|
13 |
+
<input class="area" type="text" id="uiSqft" class="floatLabel" name="Squareft" value="1000">
|
14 |
+
<h2>BHK</h2>
|
15 |
+
<div class="switch-field">
|
16 |
+
<input type="radio" id="radio-bhk-1" name="uiBHK" value="1"/>
|
17 |
+
<label for="radio-bhk-1">1</label>
|
18 |
+
<input type="radio" id="radio-bhk-2" name="uiBHK" value="2" checked/>
|
19 |
+
<label for="radio-bhk-2">2</label>
|
20 |
+
<input type="radio" id="radio-bhk-3" name="uiBHK" value="3"/>
|
21 |
+
<label for="radio-bhk-3">3</label>
|
22 |
+
<input type="radio" id="radio-bhk-4" name="uiBHK" value="4"/>
|
23 |
+
<label for="radio-bhk-4">4</label>
|
24 |
+
<input type="radio" id="radio-bhk-5" name="uiBHK" value="5"/>
|
25 |
+
<label for="radio-bhk-5">5</label>
|
26 |
+
</div>
|
27 |
+
</form>
|
28 |
+
<form class="form">
|
29 |
+
<h2>Bath</h2>
|
30 |
+
<div class="switch-field">
|
31 |
+
<input type="radio" id="radio-bath-1" name="uiBathrooms" value="1"/>
|
32 |
+
<label for="radio-bath-1">1</label>
|
33 |
+
<input type="radio" id="radio-bath-2" name="uiBathrooms" value="2" checked/>
|
34 |
+
<label for="radio-bath-2">2</label>
|
35 |
+
<input type="radio" id="radio-bath-3" name="uiBathrooms" value="3"/>
|
36 |
+
<label for="radio-bath-3">3</label>
|
37 |
+
<input type="radio" id="radio-bath-4" name="uiBathrooms" value="4"/>
|
38 |
+
<label for="radio-bath-4">4</label>
|
39 |
+
<input type="radio" id="radio-bath-5" name="uiBathrooms" value="5"/>
|
40 |
+
<label for="radio-bath-5">5</label>
|
41 |
+
</div>
|
42 |
+
<h2>Location</h2>
|
43 |
+
<div>
|
44 |
+
<select class="location" name="" id="uiLocations">
|
45 |
+
<option value="" disabled="disabled" selected="selected">Choose a Location</option>
|
46 |
+
<option>Electronic City</option>
|
47 |
+
<option>Rajaji Nagar</option>
|
48 |
+
</select>
|
49 |
+
</div>
|
50 |
+
<button class="submit" onclick="onClickedEstimatePrice()" type="button">Estimate Price</button>
|
51 |
+
<div id="uiEstimatedPrice" class="result"> <h2></h2> </div>
|
52 |
+
</body>
|
53 |
+
</html>
|
script.js
ADDED
@@ -0,0 +1,62 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
function getBathValue() {
|
2 |
+
var uiBathrooms = document.getElementsByName("uiBathrooms");
|
3 |
+
for(var i in uiBathrooms) {
|
4 |
+
if(uiBathrooms[i].checked) {
|
5 |
+
return parseInt(i)+1;
|
6 |
+
}
|
7 |
+
}
|
8 |
+
return -1;
|
9 |
+
}
|
10 |
+
|
11 |
+
function getBHKValue() {
|
12 |
+
var uiBHK = document.getElementsByName("uiBHK");
|
13 |
+
for(var i in uiBHK) {
|
14 |
+
if(uiBHK[i].checked) {
|
15 |
+
return parseInt(i)+1;
|
16 |
+
}
|
17 |
+
}
|
18 |
+
return -1;
|
19 |
+
}
|
20 |
+
|
21 |
+
function onClickedEstimatePrice() {
|
22 |
+
console.log("Estimate price button clicked");
|
23 |
+
var sqft = document.getElementById("uiSqft");
|
24 |
+
var bhk = getBHKValue();
|
25 |
+
var bathrooms = getBathValue();
|
26 |
+
var location = document.getElementById("uiLocations");
|
27 |
+
var estPrice = document.getElementById("uiEstimatedPrice");
|
28 |
+
|
29 |
+
// var url = "http://127.0.0.1:5000/predict_home_price";
|
30 |
+
var url = "api/predict_home_price";
|
31 |
+
|
32 |
+
$.post(url, {
|
33 |
+
total_sqft: parseFloat(sqft.value),
|
34 |
+
bhk: bhk,
|
35 |
+
bath: bathrooms,
|
36 |
+
location: location.value
|
37 |
+
},function(data, status) {
|
38 |
+
console.log(data.estimated_price);
|
39 |
+
estPrice.innerHTML = "<h2>" + data.estimated_price.toString() + " Lakh</h2>";
|
40 |
+
console.log(status);
|
41 |
+
});
|
42 |
+
}
|
43 |
+
|
44 |
+
function onPageLoad() {
|
45 |
+
console.log( "document loaded" );
|
46 |
+
// var url = "http://127.0.0.1:5000/get_location_names";
|
47 |
+
var url = "api/get_location_names";
|
48 |
+
$.get(url,function(data, status) {
|
49 |
+
console.log("got response for get_location_names request");
|
50 |
+
if(data) {
|
51 |
+
var locations = data.locations;
|
52 |
+
var uiLocations = document.getElementById("uiLocations");
|
53 |
+
$('#uiLocations').empty();
|
54 |
+
for(var i in locations) {
|
55 |
+
var opt = new Option(locations[i]);
|
56 |
+
$('#uiLocations').append(opt);
|
57 |
+
}
|
58 |
+
}
|
59 |
+
});
|
60 |
+
}
|
61 |
+
|
62 |
+
window.onload = onPageLoad;
|
style.css
ADDED
@@ -0,0 +1,133 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
@import url(https://fonts.googleapis.com/css?family=Roboto:300);
|
2 |
+
|
3 |
+
.switch-field {
|
4 |
+
display: flex;
|
5 |
+
margin-bottom: 36px;
|
6 |
+
overflow: hidden;
|
7 |
+
}
|
8 |
+
|
9 |
+
.switch-field input {
|
10 |
+
position: absolute !important;
|
11 |
+
clip: rect(0, 0, 0, 0);
|
12 |
+
height: 1px;
|
13 |
+
width: 1px;
|
14 |
+
border: 0;
|
15 |
+
overflow: hidden;
|
16 |
+
}
|
17 |
+
|
18 |
+
.switch-field label {
|
19 |
+
background-color: #e4e4e4;
|
20 |
+
color: rgba(0, 0, 0, 0.6);
|
21 |
+
font-size: 14px;
|
22 |
+
line-height: 1;
|
23 |
+
text-align: center;
|
24 |
+
padding: 8px 16px;
|
25 |
+
margin-right: -1px;
|
26 |
+
border: 1px solid rgba(0, 0, 0, 0.2);
|
27 |
+
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3), 0 1px rgba(255, 255, 255, 0.1);
|
28 |
+
transition: all 0.1s ease-in-out;
|
29 |
+
}
|
30 |
+
|
31 |
+
.switch-field label:hover {
|
32 |
+
cursor: pointer;
|
33 |
+
}
|
34 |
+
|
35 |
+
.switch-field input:checked + label {
|
36 |
+
background-color: #a5dc86;
|
37 |
+
box-shadow: none;
|
38 |
+
}
|
39 |
+
|
40 |
+
.switch-field label:first-of-type {
|
41 |
+
border-radius: 4px 0 0 4px;
|
42 |
+
}
|
43 |
+
|
44 |
+
.switch-field label:last-of-type {
|
45 |
+
border-radius: 0 4px 4px 0;
|
46 |
+
}
|
47 |
+
|
48 |
+
.form {
|
49 |
+
max-width: 270px;
|
50 |
+
font-family: "Lucida Grande", Tahoma, Verdana, sans-serif;
|
51 |
+
font-weight: normal;
|
52 |
+
line-height: 1.625;
|
53 |
+
margin: 8px auto;
|
54 |
+
padding-left: 16px;
|
55 |
+
z-index: 2;
|
56 |
+
}
|
57 |
+
|
58 |
+
h2 {
|
59 |
+
font-size: 18px;
|
60 |
+
margin-bottom: 8px;
|
61 |
+
}
|
62 |
+
.area{
|
63 |
+
font-family: "Roboto", sans-serif;
|
64 |
+
outline: 0;
|
65 |
+
background: #f2f2f2;
|
66 |
+
width: 76%;
|
67 |
+
border: 0;
|
68 |
+
margin: 0 0 10px;
|
69 |
+
padding: 10px;
|
70 |
+
box-sizing: border-box;
|
71 |
+
font-size: 15px;
|
72 |
+
height: 35px;
|
73 |
+
border-radius: 5px;
|
74 |
+
}
|
75 |
+
|
76 |
+
.location{
|
77 |
+
font-family: "Roboto", sans-serif;
|
78 |
+
outline: 0;
|
79 |
+
background: #f2f2f2;
|
80 |
+
width: 76%;
|
81 |
+
border: 0;
|
82 |
+
margin: 0 0 10px;
|
83 |
+
padding: 10px;
|
84 |
+
box-sizing: border-box;
|
85 |
+
font-size: 15px;
|
86 |
+
height: 40px;
|
87 |
+
border-radius: 5px;
|
88 |
+
}
|
89 |
+
|
90 |
+
.submit{
|
91 |
+
background: #a5dc86;
|
92 |
+
width: 76%;
|
93 |
+
border: 0;
|
94 |
+
margin: 25px 0 10px;
|
95 |
+
box-sizing: border-box;
|
96 |
+
font-size: 15px;
|
97 |
+
height: 35px;
|
98 |
+
text-align: center;
|
99 |
+
border-radius: 5px;
|
100 |
+
}
|
101 |
+
|
102 |
+
.result{
|
103 |
+
background: #dcd686;
|
104 |
+
width: 76%;
|
105 |
+
border: 0;
|
106 |
+
margin: 25px 0 10px;
|
107 |
+
box-sizing: border-box;
|
108 |
+
font-size: 15px;
|
109 |
+
height: 35px;
|
110 |
+
text-align: center;
|
111 |
+
}
|
112 |
+
|
113 |
+
.img {
|
114 |
+
background: url('https://images.unsplash.com/photo-1564013799919-ab600027ffc6?ixlib=rb-1.2.1&auto=format&fit=crop&w=1350&q=80');
|
115 |
+
background-repeat: no-repeat;
|
116 |
+
background-size: auto;
|
117 |
+
background-size:100% 100%;
|
118 |
+
-webkit-filter: blur(5px);
|
119 |
+
-moz-filter: blur(5px);
|
120 |
+
-o-filter: blur(5px);
|
121 |
+
-ms-filter: blur(5px);
|
122 |
+
filter: blur(15px);
|
123 |
+
position: fixed;
|
124 |
+
width: 100%;
|
125 |
+
height: 100%;
|
126 |
+
top: 0;
|
127 |
+
left: 0;
|
128 |
+
z-index: -1;
|
129 |
+
}
|
130 |
+
|
131 |
+
body, html {
|
132 |
+
height: 100%;
|
133 |
+
}
|
tempCodeRunnerFile.py
ADDED
@@ -0,0 +1,27 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import json
|
2 |
+
import pickle
|
3 |
+
|
4 |
+
|
5 |
+
__locations=None
|
6 |
+
__data_columns = None
|
7 |
+
__model =None
|
8 |
+
|
9 |
+
def get_location_names():
|
10 |
+
pass
|
11 |
+
|
12 |
+
def load_saved_artifacts():
|
13 |
+
print("loading saved artifacts...start")
|
14 |
+
global __data_columns
|
15 |
+
global __locations
|
16 |
+
|
17 |
+
with open("./artifacts/columns.json",'r') as f:
|
18 |
+
__data_columns=json.load(f)['data_columns']
|
19 |
+
__locations = __data_columns[3:]
|
20 |
+
|
21 |
+
with open("./artifacts/banglore_home_prices_model.pickle",'rb') as f:
|
22 |
+
__model == pickle.load(f)
|
23 |
+
print("loading saved artifacts ..done")
|
24 |
+
|
25 |
+
if __name__ =='__main__':
|
26 |
+
load_saved_artifacts()
|
27 |
+
print(get_location_names())
|
util.py
ADDED
@@ -0,0 +1,48 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
|
2 |
+
|
3 |
+
|
4 |
+
import json
|
5 |
+
import pickle
|
6 |
+
import numpy as np
|
7 |
+
|
8 |
+
__locations = None
|
9 |
+
__data_columns = None
|
10 |
+
__model = None
|
11 |
+
|
12 |
+
def get_estimated_price(location, sqft, bhk, bath):
|
13 |
+
try:
|
14 |
+
loc_index = __data_columns.index(location.lower())
|
15 |
+
except ValueError:
|
16 |
+
loc_index = -1
|
17 |
+
|
18 |
+
x = np.zeros(len(__data_columns))
|
19 |
+
x[0] = sqft
|
20 |
+
x[1] = bath
|
21 |
+
x[2] = bhk
|
22 |
+
if loc_index >= 0:
|
23 |
+
x[loc_index] = 1
|
24 |
+
|
25 |
+
return round(__model.predict([x])[0], 2)
|
26 |
+
|
27 |
+
def get_location_names():
|
28 |
+
return __locations
|
29 |
+
|
30 |
+
def load_saved_artifacts():
|
31 |
+
print("loading saved artifacts...start")
|
32 |
+
global __data_columns
|
33 |
+
global __locations
|
34 |
+
global __model
|
35 |
+
|
36 |
+
with open("./artifacts/columns.json", 'r') as f:
|
37 |
+
__data_columns = json.load(f)['data_columns']
|
38 |
+
__locations = __data_columns[2:]
|
39 |
+
|
40 |
+
with open("./artifacts/banglore_home_prices_model.pickle", 'rb') as f:
|
41 |
+
__model = pickle.load(f)
|
42 |
+
|
43 |
+
print("loading saved artifacts...done")
|
44 |
+
|
45 |
+
if __name__ == '__main__':
|
46 |
+
load_saved_artifacts()
|
47 |
+
print(get_location_names())
|
48 |
+
print(get_estimated_price('1st Phase JP Nagar', 1000, 3, 3))
|