| |
| |
|
|
| |
|
|
|
|
| |
| import pandas as pd |
| from sklearn.model_selection import train_test_split |
| from sklearn.linear_model import LinearRegression |
| from sklearn.metrics import r2_score,mean_squared_error |
| from sklearn.pipeline import Pipeline |
| from sklearn.compose import ColumnTransformer |
| from sklearn.preprocessing import StandardScaler,OneHotEncoder |
|
|
|
|
|
|
| |
| df=pd.read_excel('cars.xls') |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| X=df.drop('Price',axis=1) |
| y=df[['Price']] |
|
|
|
|
|
|
| X_train,X_test,y_train,y_test=train_test_split(X,y, |
| test_size=0.2, |
| random_state=42) |
|
|
|
|
|
|
|
|
| preproccer=ColumnTransformer(transformers=[('num',StandardScaler(), |
| ['Mileage','Cylinder','Liter','Doors']), |
| ('cat',OneHotEncoder(),['Make','Model','Trim','Type'])]) |
|
|
|
|
|
|
|
|
| model=LinearRegression() |
| pipe=Pipeline(steps=[('preprocessor',preproccer), |
| ('model',model)]) |
| 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) |
|
|
| import streamlit as st |
| 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], |
| 'Car_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("Used Car Price Estimation :red_car: by JamesWhiteCookJr90") |
| st.write("Enter features of the car") |
| make=st.selectbox("Make",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("Mileage",200,60000) |
| car_type=st.selectbox("Vehicle Type",df[(df['Make']==make) & (df['Model']==model) & (df['Trim']==trim )]['Type'].unique()) |
| cylinder=st.selectbox("Cylinder",df['Cylinder'].unique()) |
| liter=st.number_input("Engine Displacement",1,6) |
| doors=st.selectbox("Number of Doors",df['Doors'].unique()) |
| cruise=st.radio("Cruise Control",[True,False]) |
| sound=st.radio("Audio System",[True,False]) |
| leather=st.radio("Leather Seat",[True,False]) |
| if st.button("Predict"): |
| pred=price(make,model,trim,mileage,car_type,cylinder,liter,doors,cruise,sound,leather) |
|
|
| st.write("11062024:Predicted Price :red_car: $",round(pred[0],2)) |
|
|
|
|
|
|
|
|
|
|