@mattab opened this Issue on October 7th 2018 Member

What is personalization?

Definition from wikipedia

Personalization, broadly known as customization, consists of tailoring a service or a product to accommodate specific individuals, sometimes tied to groups or segments of individuals. A wide variety of organizations use personalization to improve customer satisfaction, digital sales conversion, marketing results, branding, and improved website metrics as well as for advertising. Personalization is a key element in social media and recommender systems.
[...]
Technically, web personalization can be achieved by associating a visitor segment with a predefined action. Customizing the user experience based on behavioural, contextual and technical data is proven to have a positive impact on conversion rate optimization efforts. Associated actions can range from changing the content of a webpage, presenting a modal display, presenting interstitials, triggering a personalized email or even automating a phone call to the user.

Why personalization matters?

Personalisation can help companies improve their websites, increase conversion rates, increase average order value, customer lifetime value, improve marketing ROI, and deliver a better user experience.

There are a few tools that offer personalization but none that are open source and give you full control over your data. And a good personalization tool will need to collect heaps of data about users (so we can create these "visitor segments"), and have complex interface to let users define the "predefined actions".

And with Matomo Analytics and Tag Manager we're in a unique position to offer personalization as a service since we already have a whole platform dedicated to measuring users and creating segments (Matomo Analytics), and a product to let people define complex actions and triggers (Matomo Tag Manager).

How would personalization work in Matomo?

Using Matomo stack personalization could work in the following way:

  • User create visitor segments using Matomo segment editor: https://matomo.org/docs/segmentation/. With Matomo segments are very powerful and you can match on 85+ dimensions and metrics like Location, Behavior on pages/clicks/downloads/videos/forms interactions, User journey, Conversions, Purchases, Time of visit, and much more. See the list here: https://developer.matomo.org/api-reference/reporting-api-segmentation#list-of-segments
  • Matomo would then compile the list of segments matched by all known visitors, so that we have a list { visitorid -> [visitorid1 segments matched ], visitorid2 -> [visitorid2 segments matched], ... } `. If we do it right, it could even be almost real-time as the list could be lazy updated every hour or more often.
  • User creates a tag, using a personalisation trigger or so, that lets user select one of the visitor segments (eg. "User has visited the website more than 10 times so far"), and then define an action (popover, message, offering special offer, etc.).
  • When a visitor browses the site, Matomo Tag Manager executes and when there's a personalization trigger, the tag manager will look up the current visitorid and checks if it matches the segment. If it does, then the tag executes and the personalised content is displayed.

This personalization would need to be an extremely fast service, as easy to use as possible, work cross-devices on the web (ie. this will be the case when using User ID instead of Visitor ID), it would eventually be possible to combine it with A/B Testing and run tests to ensure that personalised content performs better.

@tsteur commented on October 8th 2018 Member

One file per visitor in one directory could "kill" / slow down your filesystem and expose potentially lots of information as eg a 16 string unique id might not be too unique. It would also not work for first time visitors etc. Plus it doesn't really work for things like country. There are likely some better ways to do this that I had in mind a while ago where couple of them are performed in JS directly and couple bit differently.

Powered by GitHub Issue Mirror