sibeldinc commited on
Commit
c097921
1 Parent(s): cf072c7

Upload 3 files

Browse files
Files changed (3) hide show
  1. app.py +188 -0
  2. cars.xls +0 -0
  3. requirements.txt +4 -0
app.py ADDED
@@ -0,0 +1,188 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ #!/usr/bin/env python
2
+ # coding: utf-8
3
+
4
+ # # Car Prediction #
5
+ # İkinci el araç fiyatlarını (özelliklerine göre) tahmin eden modeller oluşturma ve MLOPs ile Hugging Face üzerinden yayımlayacağız.
6
+ #
7
+
8
+ # In[1]:
9
+
10
+
11
+ import pandas as pd
12
+ from sklearn.model_selection import train_test_split #veri setini bölme işlemleri
13
+ from sklearn.linear_model import LinearRegression #Doğrusal regresyon
14
+ from sklearn.metrics import r2_score,mean_squared_error #modelimizin performansını ölçmek için
15
+ from sklearn.compose import ColumnTransformer #Sütun dönüşüm işlemleri
16
+ from sklearn.preprocessing import OneHotEncoder, StandardScaler # kategori - sayısal dönüşüm ve ölçeklendirme
17
+ from sklearn.pipeline import Pipeline #Veri işleme hattı
18
+
19
+
20
+ # In[ ]:
21
+
22
+
23
+ #Excell dosyalarını okumak için
24
+
25
+
26
+ # In[2]:
27
+
28
+
29
+ get_ipython().system('pip install xldr')
30
+
31
+
32
+ # ## Veri dosyasını yükle
33
+
34
+ # In[3]:
35
+
36
+
37
+ ls
38
+
39
+
40
+ # In[5]:
41
+
42
+
43
+ df=pd.read_excel('cars.xls')
44
+ df
45
+
46
+
47
+ # In[10]:
48
+
49
+
50
+ df.info()
51
+
52
+
53
+ # In[6]:
54
+
55
+
56
+ # Veri ön işleme
57
+
58
+
59
+ # In[7]:
60
+
61
+
62
+ X=df.drop('Price',axis=1) #fiyat sütunu çıkar fiyata etki edenler kalsın
63
+ y=df['Price'] #tahmin
64
+
65
+
66
+ # In[9]:
67
+
68
+
69
+ X_train,X_test,y_train,y_test=train_test_split(X,y,test_size=0.2,random_state=42)
70
+
71
+
72
+ # #### Veri ön işleme, standartlaştırma ve OHE işlemlerini otomatikleştiriyoruz (standarlaştırıyoruz). Artık preprocess kullanarak kullanıcında arayüz aracılığıyla gelen veriyi mdoelimize uygun hale çevirebiliriz.
73
+ #
74
+
75
+ # In[11]:
76
+
77
+
78
+ preprocess=ColumnTransformer(
79
+ transformers=[
80
+ ('num',StandardScaler(),['Mileage', 'Cylinder','Liter','Doors']),
81
+ ('cat',OneHotEncoder(),['Make','Model','Trim','Type'])
82
+ ]
83
+ )
84
+
85
+
86
+ # In[12]:
87
+
88
+
89
+ my_model=LinearRegression()
90
+
91
+
92
+ # In[13]:
93
+
94
+
95
+ #pipeline ı tanımla
96
+ pipe=Pipeline(steps=[('preprocessor',preprocess),('model',my_model)])
97
+
98
+
99
+ # In[14]:
100
+
101
+
102
+ #pipeline fit
103
+ pipe.fit(X_train,y_train)
104
+
105
+
106
+ # In[16]:
107
+
108
+
109
+ y_pred=pipe.predict(X_test)
110
+ print('RMSE',mean_squared_error(y_test,y_pred)**0.5)
111
+ print('R2',r2_score(y_test,y_pred))
112
+
113
+
114
+ # In[ ]:
115
+
116
+
117
+ #isterseniz veri setinin tammamıyla tekrar eğitim yapabilirsiniz.
118
+ #pipe.fit(X,y)
119
+
120
+
121
+ # ## Streamlit ile modeli yayma/deploy/kullanıma sunma
122
+
123
+ # In[17]:
124
+
125
+
126
+ get_ipython().system('pip install streamlit')
127
+
128
+
129
+ # In[18]:
130
+
131
+
132
+ df['Mileage'].max()
133
+
134
+
135
+ # In[19]:
136
+
137
+
138
+ df['Type'].unique()
139
+
140
+
141
+ # In[20]:
142
+
143
+
144
+ df['Liter'].max()
145
+
146
+
147
+ # #### Python ile yapılan çalışmnalrın hızlı bir şekilde deploy edilmesi için HTML render arayüzler tasarlamanızı sağlar.
148
+
149
+ # In[21]:
150
+
151
+
152
+ import streamlit as st
153
+ #price tahmin fonksiyonu tanımla
154
+ def price(make,model,trim,mileage,car_type,cylinder,liter,doors,cruise,sound,leather):
155
+ input_data=pd.DataFrame({'Make':[make],
156
+ 'Model':[model],
157
+ 'Trim':[trim],
158
+ 'Mileage':[mileage],
159
+ 'Type':[car_type],
160
+ 'Cylinder':[cylinder],
161
+ 'Liter':[liter],
162
+ 'Doors':[doors],
163
+ 'Cruise':[cruise],
164
+ 'Sound':[sound],
165
+ 'Leather':[leather]})
166
+ prediction=pipe.predict(input_data)[0]
167
+ return prediction
168
+ st.title("II. El Araba Fiyatı Tahmin:red_car: @drmurataltun")
169
+ st.write('Arabanın özelliklerini seçiniz')
170
+ make=st.selectbox('Marka',df['Make'].unique())
171
+ model=st.selectbox('Model',df[df['Make']==make]['Model'].unique())
172
+ trim=st.selectbox('Trim',df[(df['Make']==make) &(df['Model']==model)]['Trim'].unique())
173
+ mileage=st.number_input('Kilometre',100,200000)
174
+ car_type=st.selectbox('Araç Tipi',df[(df['Make']==make) &(df['Model']==model)&(df['Trim']==trim)]['Type'].unique())
175
+ cylinder=st.selectbox('Cylinder',df['Cylinder'].unique())
176
+ liter=st.number_input('Yakıt hacmi',1,10)
177
+ doors=st.selectbox('Kapı sayısı',df['Doors'].unique())
178
+ cruise=st.radio('Hız Sbt.',[True,False])
179
+ sound=st.radio('Ses Sis.',[True,False])
180
+ leather=st.radio('Deri döşeme.',[True,False])
181
+ if st.button('Tahmin'):
182
+ pred=price(make,model,trim,mileage,car_type,cylinder,liter,doors,cruise,sound,leather)
183
+ st.write('Fiyat:$', round(pred[0],2))
184
+
185
+
186
+
187
+
188
+
cars.xls ADDED
Binary file (142 kB). View file
 
requirements.txt ADDED
@@ -0,0 +1,4 @@
 
 
 
 
 
1
+ streamlit==1.31.1
2
+ scikit-learn==1.4.1.post1
3
+ pandas==2.1.0
4
+ xlrd == 2.0.1