Visitor classification
In order to perform personalization, Context needs to build up a classification of your visitors.
Visitor scores (Dimensions)
Visitors are classified using visitor scores, which are a set of numeric scores that describe a visitor's behaviors, events, and profile. Each score is attached to a dimension, which is a named aspect of a visitor. Here is an example of a visitor's score vector:
- Developer: 32
- Signed up for Newsletter: 100
- Visitors from Canada: 100
Visitors receive these scores through triggering events such as matching campaigns, data from any API such as a CDP or customer database, or matching quirk attributes such as country. Let's go over each dimension type and what they are good for.
Signals
A signal is a set of criteria that define a visitor sending you a signal that they should be classified in a specific way. When a signal's criteria are matched, the visitor receives visitor score in the signal's dimension.
Signal criteria focus on observable visitor behavior, such as:
- Having a specific query string in the current URL (https://mysite.com?utm_campaign=my-campaign)
- Having a specific cookie value (my_cookie=123)
- Performing an event that is tracked by an analytics platform such as Google Analytics
- Visiting a specific page/route (/about)
A signal can consist of multiple criteria that are combined using logical operators, for example:
The visitor is from Canada and is a newsletter subscriber
The visitor is from Canada and (the province is Quebec or the province is Manitoba)
The score from a signal has a duration, which defines how long the score lasts once given. The duration can be:
- permanent: score persists as long as possible (depending on browser restrictions)
- session: score persists until the visitor is idle for a period of time defined when your site loads the Uniform Context script
- transient: score is given only when the criteria are true, and is removed as soon as they are not
When a signal is activated, the amount of score given is controlled by two settings: strength and cap.
The strength is the amount of score that is given each time the criteria are true.
For example with a signal such as 'the current page is /about' with a strength of 50, each time the visitor visits /about, they gain 50 points in the signal dimension.
Cap sets an upper bound on how much score you can get for a given signal. If our /about signal had a cap of 125, then the visitor would get 50, then 100, then 125 points and stop growing.
Together strength and cap provide powerful tools to gather visitor behavior without letting any particular signal overshadow other important signals.
Criteria types
Uniform supports the following criteria types:
| Type | Description | Example | 
|---|---|---|
| Cookie | Data stored on visitor's computers while browsing your site | When a visitor's browser has a cookie set on your site called SEGMENTvalueleads. | 
| Current page | Matches against the current page or route a visitor is on. Combines well with Page View Count = 1 to capture landing pages. Value checked does not include domain or query string data. | When the current page is the /products/widgetspage. | 
| Event | Events sent to integrated analytics in the browser. | When a Google Analytics event is triggered with name signup_form. | 
| Group | A logical grouping, which can contain child criteria in an AND/OR relationship. | Current page is /foo AND(event = barORquery = campaign). The()is a grouping of criteria. | 
| Page view count | Matches on the number of pages a visitor has visited in their current session. Combines well with Current Page and a match on count = 1 to create a Landing Page signal. | When a visitor has visited more than 3 pages during their current visit. | 
| Query string | Parameters added to the visitor's current URL by developers or marketing tools. | When a page is visited that contains utm_campaign=ppcquerystring value in the URL, such ashttps://yoursite.com/campaign?utm_campaign=ppc. | 
| Quirks | Match against values provided by integrations such as GeoIP or custom values set by developers. | When the visitor countryquirk equalsCanada. | 
Enrichments
Similar in concept to Signals, Enrichments are also a visitor score dimension. Unlike signals their score is not directly tied to a specific event or page: they are set either by a visitor viewing specific content that is tagged with the enrichment, or by a programmatic event (a developer writes code that explicitly says "add 50 score to the [enrichment name] enrichment").
Enrichments allow you to define a visitor behavior profile by tagging content items with enrichment values and automatically collecting a profile based on the content a visitor has seen. As an example you might define an Enrichment Category called "Profile" and values such as "Developer", "Marketing", "Sales", etc. Then in Uniform Canvas or your connected headless CMS, you can tag content items with these profile values that are relevant to that visitor profile. The visitor is then automatically given score in the tagged enrichment upon viewing that content.
Programmatic usage of enrichments allows you to define custom profiles for a visitor that have numeric scores. As an example on a commerce site you might wish to automatically track and select a product color based on the visitor's previous indications of color preference. In this case a Color Enrichment Category could be defined and populated with values such as "Red", "Blue", "Green", etc. When a customer chooses a color, the developer tells Uniform Context's SDK to add score to that color's enrichment value thus building up a profile of the colors the customer likes. Then when showing products that have colors, the developer can read the values of color enrichments and automatically select the most relevant preference.
Quirks
Sometimes a visitor has attributes that are not numbers that need to be matched on, such as GeoIP country or a custom classification from a ML model. For this you can use a Quirk. Quirks are key-value pairs that are stored about a visitor. They are set automatically when used with integrations such as edge services that provide GeoIP data, but can also be set by developers for custom quirk values such as data from an internal backend API that maps customer types.
Unlike signals or enrichments, quirks are not score dimensions. Quirks inform scores by being used as a criteria in a signal such as "the visitor is from Canada." Quirks may also be read using the Context SDK, enabling them to be used for custom logic or display purposes.
tip
We do not recommend storing any sensitive data in a quirk, such as PII data. With default settings quirks never leave the visitor's device, but they are not encrypted or intended to be secure.
Intents & audiences
Intents and Audiences are a way to create aggregations of visitor scores. They allow you to create score dimensions that are composed of the sum of other dimensions' scores. Aggregations enable creating high level abstractions of visitor behavior based on many inputs. This allows marketers to focus personalization investments as needed between very specific hyper-personalization (one campaign) and less time-intensive archetypical personalization (an entire audience).
An Intent is a specific reason that a visitor is visiting. For example "Buying shoes" or "Sign up for service." Visitors indicate their intent by performing actions that trigger one or more signals or enrichments that tell us why they are here. Defining such an intent within Context lets us target visitors with intent-specific content.
An Audience is a major classification of a visitor into an archetype or persona, for example "Developers", "Marketers", or "Jen the wholesaler." Audiences can be made up of any combination of signals, enrichments, or intents which allows them to become broad archetypes.
Both kinds of aggregation enable advanced aggregation using signs on their inputs. A positive (+) sign means the input's score is added to the aggregate score. A negative (-) sign means the input's score is subtracted from the aggregate score. A clear sign means the input blocks the aggregate from having any score if the input has a score.
Negative signs enable expressing a relationship where an action reduces the certainty of the intent or audience. For example a visitor submitting a sales contact form might reduce their score in the 'Competitor' audience. You can also use negative signs to create mutually exclusive intents or audiences, by referencing each other with a negative sign. In this model score in one aggregate is always subtracted from the other, and vice versa (e.g. 'Wholesale' and 'Consumer' might be mutually exclusive).
Clear signs enable advanced scenarios such as building funnels. To build a funnel, a series of intents is created to represent the steps in the funnel. Later steps in the funnel are added as clear sign inputs to the earlier steps, resulting in a funnel where only the current stage has a score. Clear signs can also be useful to prevent conflicting actions from being suggested.
Score decay
It can be desirable to decay visitor scores over time so that newer activities are stronger than older ones. With default settings, Context does not perform decay but it is a simple addition to the configuration to add a decay algorithm. Context ships with a simple linear decay implementation that decays scores at a linear rate the longer a visitor is inactive. With default linear decay settings of a 1-day grace period, 30-day decay duration, and 95% decay cap for example:
- Return visit in less than 1 day: no decay - within grace period
- Return visit in 16 days: decay is 50% of total score in each dimension (1 day grace + 15 days is half of 30-day default decay rate)
- Return visit in 31 days: decay is 95% of total score in each dimension (1 day grace + 30 days, decay cap 95%)