#!/usr/bin/env python # coding: utf-8 # # Car Prediction # # İkinci el araç fiyatlarını (özelliklerine göre) tahmin eden modeller oluşturma ve MLOPs ile Hugging Face üzerinden yayımlayacağız. import pandas as pd from sklearn.model_selection import train_test_split #Veri setini bölme işlemleri from sklearn.linear_model import LinearRegression #Dogrusal Regresyon from sklearn.metrics import r2_score, mean_squared_error #Modelimizin performansını ölçmek için from sklearn.compose import ColumnTransformer #Sütun dönüşüm işlemleri from sklearn.preprocessing import OneHotEncoder, StandardScaler #Kategori - Sayısal dönüşüm ve ölçeklendirme from sklearn.pipeline import Pipeline #Veri işleme hattı df=pd.read_excel("cars.xls") #Veri ön işleme X=df.drop('Price',axis=1) #Fiyat sutunu çıkar fiyata etki edenler kalsın y=df['Price'] #tahmin edilecek sütun X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42) # Veri ön işleme, standartlaştırma ve OHE işlemlerini otomatikleştiriyoruz (Standartlaştırıyoruz). # Artık preprocess kullanarak kullanıcıda arayüz aracılığıyla gelen veriyi uygun hale çevirebiliriz. preprocess=ColumnTransformer( transformers=[ ('num', StandardScaler(),['Mileage','Cylinder','Liter','Doors']), ('cat', OneHotEncoder(), ['Make','Model','Trim','Type']) ] ) my_model=LinearRegression() #pipline tanımlama pipe=Pipeline(steps=[('preprocessor', preprocess), ('model', my_model)]) #pipline fit edilmesi pipe.fit(X_train,y_train) y_pred=pipe.predict(X_test) mean_squared_error(y_test,y_pred)**0.5,r2_score(y_test,y_pred) # Python ile yapılan çalışmaların hızlı bir şekilde deploy edilmesi için HTML render arayüzler tasarlamamızı sağlar import streamlit as st #Fiyat tahmin fonksiyonu tanımlama def price(make,model,trim,mileage,car_type,cylinder,liter,doors,cruise,sound,leather): input_data=pd.DataFrame({'Make':[make], 'Model':[model], 'Trim':[trim], 'Mileage':[mileage], 'Type':[car_type], 'Cylinder':[cylinder], 'Liter':[liter], 'Doors':[doors], 'Cruise':[cruise], 'Sound':[sound], 'Leather':[leather]}) prediction=pipe.predict(input_data)[0] return prediction st.title("II. El Araba Fiyat Tahmini::red_car: @miturkoglu96") st.write('Arabanın özelliklerini seçiniz') make=st.selectbox('Marka',df['Make'].unique()) model=st.selectbox('Model',df[df['Make']==make]['Model'].unique()) trim=st.selectbox('Trim',df[(df['Make']==make)&(df['Model']==model)]['Trim'].unique()) mileage=st.number_input('Kilometre',200,60000) car_type=st.selectbox('Araç Tipi',df[(df['Make']==make) &(df['Model']==model)&(df['Trim']==trim)]['Type'].unique()) cylinder=st.selectbox('Silindir',df['Cylinder'].unique()) liter=st.number_input('Yakıt Hacmi',1,6) doors=st.selectbox('Kapı Sayısı',df['Doors'].unique()) cruise=st.radio('Hız Sabitleyici',[True,False]) sound=st.radio('Ses Sistemi',[True,False]) leather=st.radio('Deri Döşeme',[True,False]) if st.button('Tahmin Et'): pred=price(make,model,trim,mileage,car_type,cylinder,liter,doors,cruise,sound,leather) st.write('Tahmini Fiyat :red_car: $', round(pred, 2))