Join the conversation
data:image/s3,"s3://crabby-images/ba493/ba493f62628ff2a665f196a193bf1226adb02606" alt=""
done
Reply
data:image/s3,"s3://crabby-images/ead1b/ead1b488bcc0a2e09d4c7d907ee45f80027e8e70" alt=""
I learned about how to select the best models and how to do the hyperparameter Tuning on datasets.
Reply
data:image/s3,"s3://crabby-images/c28af/c28af5d3ff972f808c04e7a1d1325b6e653f4136" alt=""
Done
Reply
data:image/s3,"s3://crabby-images/7561c/7561c36ffc4438209093523f0772bf5ad462cc20" alt=""
Done
Reply
data:image/s3,"s3://crabby-images/ddf5d/ddf5daf347ea1932ac668f9d0833e6b5dbe365ac" alt=""
from sklearn.pipeline import Pipeline
from sklearn.model_selection import GridSearchCV
from sklearn.preprocessing import StandardScaler
from sklearn.linear_model import LinearRegression
from sklearn.tree import DecisionTreeRegressor
from sklearn.svm import SVR
from sklearn.ensemble import RandomForestRegressor# Define a list of models with their respective parameter grids
models = [
('LinearRegressor', Pipeline([
('preprocessor', StandardScaler()),
('model', LinearRegression())
]), {}),
('DecisionTreeRegressor', Pipeline([
('preprocessor', StandardScaler()),
('model', DecisionTreeRegressor())
]), {'model__max_depth': [None, 50, 100], 'model__criterion': ['mse', 'mae']}),
('SVR', Pipeline([
('preprocessor', StandardScaler()),
('model', SVR())
]), {'model__kernel': ['rbf', 'sigmoid'], 'model__C': [0.1, 1, 0.01]}),
('RandomForestRegressor', Pipeline([
('preprocessor', StandardScaler()),
('model', RandomForestRegressor())
]), {'model__max_depth': [None, 5, 10]})
]best_model = None
best_score = 0# Loop through each model and its parameter grid
for model_name, model, param_grid in models:
# Perform grid search if a parameter grid is provided
if param_grid:
grid_search = GridSearchCV(model, param_grid, cv=5)
grid_search.fit(X_train, y_train)best_params = grid_search.best_params_
best_model_score = grid_search.best_score_# print(f"Best parameters for {model_name}: {best_params}")
# print(f"Best score for {model_name}: {best_model_score}")if best_model_score > best_score:
best_model = grid_search.best_estimator_
best_score = best_model_score
else:
# Fit the model directly without grid search
model.fit(X_train, y_train)
score = model.score(X_train, y_train)print(f"Score for {model_name}: {score}")if score > best_score:
best_model = model
best_score = scoreprint(f"The best model is {best_model}")
Reply
data:image/s3,"s3://crabby-images/3536a/3536ae589e667dc2d438bc09489825a0dc00d5dd" alt=""
I have done this lecture with 100% practice.
Reply
data:image/s3,"s3://crabby-images/3aa3a/3aa3a99fee6cb4aa2b2215a22f258a2b8512fa0c" alt=""
I have done this video with 100% practice.
Reply
data:image/s3,"s3://crabby-images/ddf5d/ddf5daf347ea1932ac668f9d0833e6b5dbe365ac" alt=""
from sklearn.pipeline import Pipeline
from sklearn.model_selection import GridSearchCV
from sklearn.preprocessing import StandardScaler
from sklearn.linear_model import LinearRegression
from sklearn.tree import DecisionTreeRegressor
from sklearn.svm import SVR
from sklearn.ensemble import RandomForestRegressor# Define a list of models with their respective parameter grids
models = [
('LinearRegressor', Pipeline([
('preprocessor', StandardScaler()),
('model', LinearRegression())
]), {}),
('DecisionTreeRegressor', Pipeline([
('preprocessor', StandardScaler()),
('model', DecisionTreeRegressor())
]), {'model__max_depth': [None, 50, 100], 'model__criterion': ['mse', 'mae']}),
('SVR', Pipeline([
('preprocessor', StandardScaler()),
('model', SVR())
]), {'model__kernel': ['rbf', 'sigmoid'], 'model__C': [0.1, 1, 0.01]}),
('RandomForestRegressor', Pipeline([
('preprocessor', StandardScaler()),
('model', RandomForestRegressor())
]), {'model__max_depth': [None, 5, 10]})
]best_model = None
best_score = 0# Loop through each model and its parameter grid
for model_name, model, param_grid in models:
# Perform grid search if a parameter grid is provided
if param_grid:
grid_search = GridSearchCV(model, param_grid, cv=5)
grid_search.fit(X_train, y_train)best_params = grid_search.best_params_
best_model_score = grid_search.best_score_# print(f"Best parameters for {model_name}: {best_params}")
# print(f"Best score for {model_name}: {best_model_score}")if best_model_score > best_score:
best_model = grid_search.best_estimator_
best_score = best_model_score
else:
# Fit the model directly without grid search
model.fit(X_train, y_train)
score = model.score(X_train, y_train)print(f"Score for {model_name}: {score}")if score > best_score:
best_model = model
best_score = scoreprint(f"The best model is {best_model}")