With so much to do, one of the major mistakes that companies make when they start A/B testing activities is sticking to a small, basic audience. This does not yield the most meaningful results or sometimes, the results could be misleading.
Â
A/B testing (also known as split testing) is a process of showing two variants of the same web page to different segments of website visitors at the same time and comparing which variant drives more conversions. One of the most critical steps for conducting A/B testing along with research and formulating a hypothesis is to create a variation based on your hypothesis, and A/B test it against the existing version (control).
Â
A variation is another version of your current version with changes that you want to test.
Â
User segmentation is a way of categorizing your website visitors into groups, based on specific criteria such as location, the device used to access the site, the hour of the day, or any other user behaviors. For example, sorting users by region, language, or behavior. The better teams are at segmenting their users, the more personably they can treat each group.
Â
According to a study conducted by Mixpanel, eighty-one percent of consumers today wish companies knew them better, while ninety-four percent of marketers wish they knew their customers better. Why aren’t the two just talking it out? Because communicating with users is a science-powered art, and intuiting what users want requires tools, time, and proper segmentation.
Â
Let us assume (we’ll call this as our hypothesis) that Peter owns a computer e-commerce store in Canada, and wants to show a ‘Friday Macbook Special’ offer page only to people who don’t yet own a Mac computer. He also thinks that people who own an iPhone/iPad might be interested in buying a mac computer.
Â
Let us now explore how I designed a custom user segmentation tool, for selecting a specific segment of visitors, whom the user would like to show a special version of his webpage to build a better product and increase conversions.
The approach
Segregating And-Or
The problem in designing interface for rule-engines is that there is an impedance mismatch between a user and developer/maintainer for the rule engine. The most common cause of confusion when creating rules with and/or is that users generally don't know the precedence rules for the logical operators. This often creates situations where the intended results don't get generated for rules created by a user.
Â
Consider the following rule created by a user composed using and,or logical operators:
Â
rule-1 and rule-2 or rule-3 and rule-4 or rule-5 or rule-6 and rule-7 and rule-8
Â
And user meant the following:
Â
rule-1 and (rule-2 or rule-3) and (rule-4 or rule-5 or rule-6) and rule-7 and rule-8
Â
When getting evaluated, rule engine use precedence rules of operators and understands the above expression as follows
Â
(rule-1 and rule-2) or (rule-3 and rule-4) or rule-5 or (rule-6 and rule-7 and rule-8)
Â
This is clearly unintended, but this causes user frustration and confusion and thereby leads to cognitive load as they need to be extra cautious while creating segmentation rules.
Â
How does my UI module fixes the problem?
My UI module enables users to create segmentations that abide by the precedence rules of logical operators that tries to simulate creating logical groupings that explicitly state the order of evaluation.
Â
It works as follows:
- Segment definition is composed of a collection of segment chunks.
- Each segment chunk can only contain conditions connected with
and
logical operator.
- Segment chunks are connected amongst themselves with
or
logical operator
Â
Considering the rule example above, each logical grouping of
and
conditions are packaged inside a segment chunk, and, or
conditions are recorded as collection of segment chunks. This allows user to focus on building a rule set consisting of and
conditions in isolation and re-use it in multiple hypothesis.Â
data:image/s3,"s3://crabby-images/df00d/df00ddd58e3c047f948f209f5a1fba32c3c2a47b" alt="notion image"
Â
Containment operators
Containment operator such as
isOneOf
makes it easier to create rules for a segment having multiple possible values within one category. These operators make it possible to avoid creating multiple segment chunks by transforming implicit or
condition to an and
condition.For eg. consider the following rule
All users from Hungary visiting website using iPhones via Safari, Chrome or Firefox
The atomic rule can be created as follows
Location = Hungary and
device = iPhone and (browser = Safari or
browser = Chrome or
browser = firefox)
Â
The same query can be transformed into an all
and
query using isOneOf
operatorLocation = Hungary and
device = iPhone and
browser isOneOf
[Safari, Chrome, Firefox]
Â
Containment operators only works for intra category values. Foror
condition on inter-category values, explicitor
conditions need to be created.
Â
data:image/s3,"s3://crabby-images/98c98/98c9835e9b5ac624857e21ab84c90fdfaae37290" alt="notion image"
Â
Examples
Let's see how segment chunks can work across two different examples that make this point clear.
Â
Example 1: All users from US using MacBooks or Users from UK having iOS device visiting the website on Fridays.
Â
The above segment can be created using a single segment chunk as follows:
Day = Friday and Location isOneOf [US, UK] and OS isoneOf [macOS, iOS]
Â
Example 2: Users from Italy using firefox on iPhone or IE on desktop only on Fridays
The above example can be constructed easily using two segment chunks as follows:
Â
# chunk 1 (Location = Italy and device = iPhone and browser = firefox ) or # chunk 2 (Location = Italy and browser = IE)
Â
Â
Now that you have an understanding of how the user segmentation works, let us go back to the original problem statement
Peter owns a computer e-commerce store in Canada, and wants to show a ‘Friday Macbook Special’ offer page only to people who don’t yet own a Mac computer. He also thinks that people who own an iPhone/iPad might be interested in buying a mac computer.
Â
This is how the segmentation for the above hypothesis will look like along with the hypothesis and URL(s)
Â
data:image/s3,"s3://crabby-images/28615/28615d567ff728cd816a2df780fc3b0146f4c0a8" alt="Creating segment 1"
Â
The creation of the second segment can be done easily by copying the conditions or operands from the previous segments like this
Â
data:image/s3,"s3://crabby-images/dd3f5/dd3f58c49fbcd949d229ef4f2576c0b6f9d3158a" alt="notion image"
Â
Â
The final segmentation of the above use-case will look like
Â
data:image/s3,"s3://crabby-images/93727/93727c8686d64a45213cabb694f7cb126a8b1516" alt="The final segments created for the hypothesis"