An Indonesian company is interested in evaluating the performance of advertisement on their website. This evaluation is essential for the company as it helps gauge the advertisement’s reach and its ability to engage customers.
By analyzing historical advertisement data and uncovering insights and trends, this approach can aid the company in defining their marketing objectives. In this specific case, the primary emphasis lies in developing a machine learning classification model that can accurately identify the target customer demographic.
- The company in question currently displays ads for all of its users. This “shotgun” strategy yields them an ad click rate of 50%.
- The company spends a nonoptimal amount of resources by displaying ads for all of its users.
- Create well-fit machine learning models that can reliably predict which users are likely to click on an ad.
- Determine the best machine learning model to be implemented in this use case based on; evaluation metrics (Recall and Accuracy), model simplicity, and prediction time.
- Identify the factors that most influence users’ likelihood to click on an ad.
- Provide recommendations for potential strategies regarding targeted ads to marketing and management teams based on findings from analyzes and modeling.
- Calculate the potential impact of model implementation on profit and click rate.
The dataset was obtained from Rakamin Academy.
Description:
- Unnamed: 0= ID of Customers
- Daily Time Spent on Site= Time spent by the user on a site in minutes
- Age= Customer’s age in terms of years
- Area Income= Average income of geographical area of consumer
- Daily Internet Usage= Average minutes in a day consumer is on the internet
- Male= Gender of the customer
- Timestamp= Time at which user clicked on an Ad or the closed window
- Clicked on Ad= Whether or not the customer clicked on an Ad (Target Variable)
- city= City of the consumer
- province= Province of the consumer
- category= Category of the advertisement
Overview:
- Dataset contains 1000 rows, 10 features and 1 Unnamed: 0column which is the ID column.
- Dataset consists of 3 data types; float64, int64 and object.
- Timestampfeature could be changed into datetime data type.
- Dataset contains null values in various columns.
Boxplot of Numerical Features
Analysis:
- Area Incomeis the only feature with a slight skew (left-skewed).
- Daily Internet Usageis nearly uniformly distributed.
- While AgeandDaily Time Spent on Siteis nearly normally distributed.
Boxplot of Numerical Features Between Users That Clicked and Didn’t Click On Ad
Analysis:
- The more time is spent on site by the customer the less likely they will click on an ad.
- The average age of customers that clicked on an ad is 40, while the average for those that didn’t is 31.
- The average area income of customers that clicked on an ad is considerably lower than those that didn’t.
- Similar to time spent, the more the daily internet usage is, the less likely the customer will click on an ad.
- As can be seen the last scatterplot above, there is a quite clear separation between two clusters of data. One cluster is less active and the other more so. Less active customers have a higher tendency to click on an ad compared to more active customers.
Since the target variable is binary (Clicked or didn’t click), we can’t use the standard Pearson correlation to see the correlation between the numerical features and the target. Hence, the Point Biserial correlation was used to analyze the correlation between the target and the numerical features.
In order to see the correlation between categorical features, I again couldn’t employ the standard Pearson correlation. There are numerous methods out there, but in this study I used Cramer’s V to understand the association and by extension the correlation between categorical features.
Analysis:
- The perfect correlation coefficient of 1 indicates that cityandprovinceare perfectly associated. This makes sense, since if you knew the city you would also know the province. This means that using both features for machine learning modeling is redundant.
- All the numerical features (especially Daily Internet UsageandDaily Time Spent on Site) have high correlation with the target variable.
Missing or null values were present in various columns in the data. These null values were imputed using statistically central values such as mean or median accordingly.
The Timestamp feature was of “object” data type. This feature was transformed into “date-time” data type in order to have its contents extracted. There are 3 extra features that were extracted from the Timestamp feature, these are:
- Month
- Week
- Day (Mon-Sun)
Outliers were present in the Area Income feature. To help the data in becoming more “model friendly” to linear and distance based models, these outliers were removed from the data (using IQR method).
Before:
After:
From the multivariate analysis it can be seen that city and province are redundant. However, both features have high cardinality and don’t correlate too well with the target variable. As a result, both of these features were excluded in the modeling as to prevent the curse of dimensionality. Timestamp was also excluded since its contents have been extracted and it was no longer needed. Unnamed: 0 or ID was obviously excluded since it is an identifier column and is unique for every user.
The categorical features were encoded so that machine learning models could read and understand its values. The category feature was One-Hot encoded whilst the rest (Gender and Clicked on Ad) were label encoded.
The data was split into training and testing sets. This is common practice as to make sure that the machine learning models weren’t simply memorizing the answers from the data it was given. The data was split in a 75:25 ratio, 75% training data and 25% testing data.
In the modeling phase, an experiment was conducted. Machine learning models were trained and tested with non-normalized/non-standardized version of the data. The results of which were compared to models trained and tested with normalized/standardized version of the data. Hyperparameter tuning was done in both scenarios, as to get the best out of each model. The model and standardization method with the best results will be selected. Six models were experimented with, these are:
- Logistic Regression
- Decision Tree
- Random Forest
- K-Nearest Neighbors
- Gradient Boosting
- XGBoost
Because the target has perfect class balance the primary metric that will be used is
Accuracy. Recall will be the secondary metric as to minimize false negatives.
Results:
Observation:
- Decision Treehad the lowest fit time of all the models but the second lowest accuracy overall.
- Gradient Boostinghad the highest accuracy and recall scores but- XGBoostis not far behind.
- Due to the non-normalized data, distance based algorithms like K-Nearest Neighboursand linear algorithms likeLogistic Regressionsuffered heavily.- Logistic Regressioncould not converge properly using newton-cg and as a result had the highest fit time of all the models, even though it probably is the simplest model of them all.
- K-Nearest Neighbourssuffered in accuracy and recall scores, with both being by far the lowest of all the models tested.
 
Results:
Observation:
- K-Nearest Neighbourshad the highest fit time and elapsed time.
- Gradient Boostinghad the highest accuracy and the highest recall (tied with- Random Forest), but- Logistic Regressionin close second, had the highest cross-validated accuracy of all the models tested.
- Random Forestand- XGBoostalso had nearly identical scores in close third and fourth, although- XGBoosthad the better fit and elapsed times.
- With normalized data, the previously poor performing distance based and linear models have shone through.
- Logistic Regression's fit and elapsed times had been reduced significantly making it the model with the lowest times. It's scores have also massively improved making it a close second-place model.
- K-Nearest Neighboursalso saw massive improvement in its scores, with the model no longer sitting in last place in terms of scores.
 
By taking consideration of not only the above metrics but also the simplicity, explainability and fit and elapsed times, the model that will be chosen is the Logistic Regression model with normalization/standardization. This is not only because of the very high scores (especially cross-validated scores) but also the simplicity, explainability and relatively quick fit and elapsed times.
Learning Curve:
As can be seen from the above learning curve, the tunedLogistic Regression model with normalization/standardization is well fitted with no overfitting/underfitting.
Confusion Matrix:
From the test set confusion matrix above, from 120 people that clicked on an ad the algorithm correctly classified 116 of them and incorrectly classified 4 of them. Similarly, out of 128 people that did not click on an ad the algorithm correctly classified 124 of them and incorrectly classified only 4.
Based on the confusion matrix and also the learning curve, it can be seen that Logistic Regression is a more than capable model to be implemented on this dataset.
Feature Importance:
Since Logistic Regression is such a simple and explainable model, to get the feature importance we can simply look at the coefficients of each feature in the model.
The coefficients represent the change in the log odds for a one-unit change in the feature variable. Larger absolute values indicate a stronger relationship between the feature and the target variable, while the sign of the coefficients (negative or positive) indicates the direction of the relationship between the two.
Analysis:
Based on the feature importance charts above, it can clearly be seen that the two features with most effect on the model are Daily Time Spent on Site and Daily Internet Usage.
- The lower the Daily Time Spent on Sitethe bigger the odds that the customer will click on an ad and vice versa.
- Similarly, the lower the Daily Internet Usagethe higher the chances that the customer will click on an ad and vice versa.
- Other Important features include; Area IncomeandAge.
Based on the insights that have been gathered in the EDA as well as the feature importance from the model, the following business recommendations are formulated.
- Content Personalization and Targeting: Since the lower the Daily Time Spent on Site is the more likely the user is to click on an ad, it’s essential to focus on content personalization and user engagement. Tailor content to keep users engaged but not overloaded. This can be achieved through strategies like recommending relevant content and using user data to customize the user experience.
- Age-Targeted Advertising: Older individuals are more likely to engage with ads. Therefore we can consider creating ad campaigns that are specifically designed to target and appeal to older demographics. This may include promoting products or services relevant to their age group.
- Income-Level Targeting: Users in areas with lower income levels are more likely to click on ads. Therefore we can create ad campaigns that are budget-friendly and appealing to users with lower income. Additionally, consider tailoring the ad messaging to highlight cost-effective solutions.
- Optimize Ad Placement for Active Internet Users: Heavy internet users are less responsive to ads. To improve ad performance, consider optimizing ad placement for users with lower internet usage or finding ways to make ads stand out to this group, such as through eye-catching visuals or unique offers.
Assumption:
Cost per Advertisement: Rp.1000
Revenue per Ad clicked: Rp.4000
Before model implementation:
- No. Users Advertised:
 Every User = 1000
- Click Rate: 
 500/1000 = 50%
- Total Cost: 
 No. Users Advertised x Cost per Ad = 1000 x 1000 = Rp.1,000,000
- Total Revenue: 
 Click Rate x No. Users Advertised x Revenue per Ad Clicked = 0.5 x 1000 x 4000 = Rp.2,000,000
- Total Profit:
 Total Revenue - Total Cost = Rp.1,000,000
After model implementation:
- No. Users Advertised:
 (Precision x 500) + ((1-Specificity) x 500) = (96.67% x 500) + (0.03125 x 500) = 483 + 16 = 499
- Click Rate:
 (Precision x 500)/No. Users Advertised = 483/499 = 96.8%
- Total Cost:
 No. Users Advertised x Cost per Ad = 499 x 1000 = Rp.499,000
- Total Revenue:
 Click Rate x No. Users Advertised x Revenue per Ad Clicked = 0.968 x 499 x 4000 = Rp.1,932,000
- Total Profit:
 Total Revenue - Total Cost = 1,932,000 - 499,000 = Rp.1,433,000
Conclusion:
By comparing the profits and click rates of before and after model implementation, we can see that with model implementation click rate is up from 50% to 96.8%, and similarly profit is up from Rp.1,000,000 to Rp.1,433,000 (a 43.3% increase).



















