von Evangelia Soultani
Personalization has become an important aspect of our lives. Disruptive companies such as Amazon or Netflix have taken personalization to the next level by providing users with personalized product and content recommendations. Today more than ever users expect a personalized experience when shopping online and therefore, more and more companies are becoming interested in integrating Recommendation Engines into their businesses. Thanks to availability of Raw Data, Cloud Computing services and Machine Learning (ML) algorithms it is nowadays possible for any company to build and scale such engines according to their business needs. In this article we provide a brief overview of Recommendation Engines and summarize the various solutions offered by Google Cloud Platform (GCP) .
Machine Learning mit eigenen Daten, zurechtgeschneidert auf eigene Business Cases bringt riesiges Potential und ist der Schlüssel für weitere Wettbewerbsfähigkeit.
Mehr ErfahrenA Recommendation Engine is a system that provides personalized product and content recommendations to users. Such systems are driven by Machine Learning algorithms and utilize data that contain prior knowledge about users‘ known interests and interactions.
Three of the main approaches for Recommendation Engines are:
Which approach should a company choose though? Before deciding, it is important to assess the concept of Recommendation Engines from three main perspectives:
Identifying the business objective is the first prerequisite that should be fulfilled in order to make sure that the recommendations will ultimately achieve the desired outcome for a business.
For example if the objective is to increase the revenue of a wide variety of products, then a Recommendation Engine could be optimized to suggest to users more diverse products . On the other hand, if the objective is to improve the user experience, the recommendations could be based for example on products that fit well together or products that are liked or viewed by users with similar interests.
Another important aspect is to understand how a Recommendation Engine is intended to be used. For example, will the recommendations be presented to users in real time as soon as they visit a website, an app or even a store in person? Or will the strategy be instead to serve recommendations periodically via an email, display and video advertising campaign? Will the users interact with it for example by giving feedback about the recommendations?
Such decisions will definitely have an impact not only on the Machine Learning method but also on the overall architecture of the Recommendation Engine and thus, they should be addressed at a very early stage of the development phase.
Developing a Recommendation Engine that is based on Machine Learning techniques requires large volumes of historical user and product data. Such data is fed to Machine Learning models to optimize their ability to make predictions on recommendations.
As a result of this, poor quality data can lead to poor recommendations (concept known in machine learning as “Garbage in, garbage out”). A good practise is to analyze the available data and assess whether it is relevant and sufficient for building a Recommendation Engine. Knowing for example if the product catalog contains many items, how often the product catalog data is updated as well as if there is data capturing users feedback, will definately simplify the decision making process.
Even if the data is available, having the right capabilities to identify the business needs (Business Understanding) as well as to process the data and implement the solution (Cloud & Data Science) is the key to delivering a Recommendation Engine that will eventually create value for the company and its customers.
 
											Currently, Google Cloud Platform offers four possible ways to leverage state of the art Machine Learning techniques and deploy Recommendation Engines in the cloud.
BigQuery ML is a great tool for low cost and fast implementations of Recommendation Engines, however currently supports only one specific recommendation type ( recommends to users only products which are liked or viewed by other users with similar interests). The models are created using SQL and can be accessed in BigQuery via a Web User Interface (Rest API, command line tools and external tools such as jupyter notebooks are also supported). When it comes to performance tests (such as A/B testing), a separate implementation needs to be integrated with this solution.
 
											On the other hand, Recommendations AI offers more of an end to end solution, supporting a wider range of recommendation types while providing a User Interface which simplifies the process of monitoring and testing the performance of recommendations. Further advantages include its ability to take into account the users phase in the customer journey and that it can be activated in multiple touchpoints and channels. It definitely minimizes the effort that is required to build a Recommendation Engine, since it does not require expertise in ML or domain knowledge. Keep in mind though that it comes with higher runtime costs and less flexibility for customization.
AI Platform is a development platform which allows quick and cost-efficiently deployment of ML projects. It definitely requires a certain level of ML expertise and domain knowledge for preparing, building, validating and deploying ML models. When it comes to Recommendation Engines, AI platform offers the possibility to use one of its built-in algorithms (Wide & Deep) which has been used in the past for increasing app acquisitions in Google Play.
Self Customized Recommendation Engines on the other hand offer the most flexibility but require ML, domain expertise as well as higher development and maintenance efforts.
Below you can see a quick summary of what each solution can offer:
| BigQuery ML | Recommendations AI | AI Platform | Self Built & Customized | |
| Recommendation Type | “Products liked by users with similar interests” | “Other products you may like” | “Most relevant products” | Depends on the selected method, for example: “Similar products”, “Products liked by users with similar interests” | 
| “Frequently bought together” | ||||
| “Recommended for you” | ||||
| “Recently viewed” | ||||
| Method | Matrix factorization | Not disclosed | Wide & Deep | Hybrid | 
| Data Source | Product ids | Product catalog | Product catalog | Product catalog User events | 
| User ids | User events from a wide range of data sources | User events from a wide range of data sources | User events from a wide range of data sources | |
| Implicit or explicit feedback | Optionally other relevant data sources | Optionally other relevant data sources | Optionally other relevant data sources | |
| Domain Knowledge | Low | Low | High | High | 
| Development Effort | Medium | Low | Medium | High | 
| Runtime Cost | Medium | High | Medium | Low | 
| Configuration UI | No | Yes | No | No | 
| Customization | Low | Low | Medium | High | 
| Performance Measuring | Can be customized | Incorporated in the UI | Can be customized | Can be customized | 
| A/B testing | Can be customized | Implicit | Can be customized | Can be customized | 
When searching for Recommendation Engines you will find a plethora of well known vendors offering out of the box software. Even though many of them offer great solutions there are several points that one must be aware of:
Recommendation Engines are definitely here to stay and shape the future of how users experience online shopping. Leveraging Google Cloud Platform services can definitely accelerate the process of building a scalable Recommendation Engine that will create value for your company and your customers.
Wir freuen uns auf Ihre Anfrage und beraten Sie gerne unverbindlich! Füllen Sie dazu einfach das Kontaktformular aus oder rufen uns direkt an.
Jetzt kontaktieren