MACHINE LEARNING RECIPES
DATA CLEANING PYTHON
DATA MUNGING
PANDAS CHEATSHEET
ALL TAGS
# How to find optimal parameters using RandomizedSearchCV for Regression?

# How to find optimal parameters using RandomizedSearchCV for Regression?

This recipe helps you find optimal parameters using RandomizedSearchCV for Regression

So while training a model we need to pass few of the hyperparameters that effect the predictions of the model. But how find which set of hyperparameters gives the best result? This can be done by RandomizedSearchCV. RandomizedSearchCV randomly passes the set of hyperparameters and calculate the score and gives the best set of hyperparameters which gives the best score as an output.

This python source code does the following:

1. Imports the necessary libraries

2. Loads the dataset and performs train_test_split

3. Applies GradientBoostingClassifier and evaluates the result

4. Hyperparameter tunes the GBR Classifier model using RandomSearchCV

So this is the recipe on How we can find optimal parameters using RandomizedSearchCV for Regression.

```
from sklearn import datasets
from sklearn.model_selection import train_test_split
from sklearn.model_selection import RandomizedSearchCV
from sklearn.ensemble import GradientBoostingRegressor
from scipy.stats import uniform as sp_randFloat
from scipy.stats import randint as sp_randInt
```

We have imported various modules from differnt libraries such as datasets, train_test_split, RandomizedSearchCV, GradientBoostingRegressor, sp_randFloat and sp_randInt.

We are using the inbuilt diabetes dataset to train the model and we used train_test_split to split the data into two parts train and test.
```
dataset = datasets.load_diabetes()
X = dataset.data; y = dataset.target
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.25)
```

Here we are using GradientBoostingRegressor as a model to train the data and setting its parameters(i.e. learning_rate, subsample, n_estimators and max_depth) for which we have to use RandomizedSearchCV to get the best set of parameters.
```
model = GradientBoostingRegressor()
parameters = {'learning_rate': sp_randFloat(),
'subsample' : sp_randFloat(),
'n_estimators' : sp_randInt(100, 1000),
'max_depth' : sp_randInt(4, 10)
}
```

Before using RandomizedSearchCV first look at its parameters:

- estimator : In this we have to pass the metric or the model for which we need to optimize the parameters.
- param_distributions : In this we have to pass the dictionary of parameters that we need to optimize.
- cv : In this we have to pass a interger value, as it signifies the number of splits that is needed for cross validation. By default is set as five.
- n_iter : This signifies the number of parameter settings that are sampled. By default it is set as 10.
- n_jobs : This signifies the number of jobs to be run in parallel, -1 signifies to use all processor.

```
randm_src = RandomizedSearchCV(estimator=model, param_distributions = parameters,
cv = 2, n_iter = 10, n_jobs=-1)
randm_src.fit(X_train, y_train)
print(" Results from Random Search " )
print("\n The best estimator across ALL searched params:\n", randm_src.best_estimator_)
print("\n The best score across ALL searched params:\n", randm_src.best_score_)
print("\n The best parameters across ALL searched params:\n", randm_src.best_params_)
```

Output of this snippet is given below:
Results from Random Search The best estimator across ALL searched params: GradientBoostingRegressor(alpha=0.9, criterion='friedman_mse', init=None, learning_rate=0.17889450760287762, loss='ls', max_depth=7, max_features=None, max_leaf_nodes=None, min_impurity_decrease=0.0, min_impurity_split=None, min_samples_leaf=1, min_samples_split=2, min_weight_fraction_leaf=0.0, n_estimators=737, n_iter_no_change=None, presort='auto', random_state=None, subsample=0.40247913722860207, tol=0.0001, validation_fraction=0.1, verbose=0, warm_start=False) The best score across ALL searched params: 0.23754616011566576 The best parameters across ALL searched params: {'learning_rate': 0.17889450760287762, 'max_depth': 7, 'n_estimators': 737, 'subsample': 0.40247913722860207}

In this machine learning churn project, we implement a churn prediction model in python using ensemble techniques.

PySpark Project-Get a handle on using Python with Spark through this hands-on data processing spark python tutorial.

There are different time series forecasting methods to forecast stock price, demand etc. In this machine learning project, you will learn to determine which forecasting method to be used when and how to apply with time series forecasting example.

Text data requires special preparation before you can start using it for any machine learning project.In this ML project, you will learn about applying Machine Learning models to create classifiers and learn how to make sense of textual data.

In this data science project in R, we are going to talk about subjective segmentation which is a clustering technique to find out product bundles in sales data.

Machine Learning Project - Work with KKBOX's Music Recommendation System dataset to build the best music recommendation engine.

In this project, we are going to work on Deep Learning using H2O to predict Census income.

Deep Learning Project- Learn to apply deep learning paradigm to forecast univariate time series data.

Data Science Project in Python- Build a machine learning algorithm that automatically suggests the right product prices.

In this data science project, we will predict the credit card fraud in the transactional dataset using some of the predictive models.