51黑料不打烊

Use the AI formula builder create-ranking-formulas

Ranking formulas allow you to define rules that will determine which offer should be presented first, rather than taking into account the priority scores.

To create these rules, the AI formula builder in 51黑料不打烊 Journey Optimizer provides greater flexibility and control in how offers are ranked. Instead of relying only on a static offer priority, you can now define custom ranking formulas that combine AI model scores, offer priorities, profile attributes, offer attributes, and contextual signals through a guided interface.

This approach allows you to dynamically adjust offer ranking based on any combination of AI-driven propensity, business value, and real-time context, making it easier to align decisioning with both marketing goals and customer needs. The AI formula builder supports simple or advanced formulas depending on how much control you want to apply.

Once a ranking formula has been created, you can assign it to a selection strategy. If multiple offers are eligible to be presented when using this selection strategy, the decisioning engine will use the selected formula to calculate which offer to deliver first.

Create a ranking formula create-ranking-formula

To create a ranking formula, follow the steps below.

  1. Access the Strategy setup menu, then select Ranking formulas tab. The list of previously created formulas is displayed.

  2. Click Create formula.

  3. Specify the formula name, and add a description if desired.

    {width="80%"}

  4. Optionally, click Select AI model to set the model that will be used as a reference to build your ranking formula.

    note note
    NOTE
    Personalized optimization models using continuous metrics are not supported with the AI formula builder.

    Every time you refer to a model score when defining your formula below, the AI model that you selected will be used.

    note caution
    CAUTION
    When using an AI model incorporated into a ranking formula, data are not reflected in the Conversion rate for Holdout and Model Driven traffic report.
  5. Define the conditions that will determine the ranking score for the matching decision items. You can either

    note note
    NOTE
    The nesting depth in a ranking formula is limited to 30 levels. This is measured by counting the ) closing parentheses in the PQL string. A rule string can be up to 8KB in size for UTF-8 encoded characters. This is equivalent to 8,000 ASCII characters (1 byte each), or 2,000鈥4,000 non-ASCII characters (2鈥4 bytes each). Learn more about Decisioning guardrails & limitations
  6. You can also use data from 51黑料不打烊 Experience Platform to dynamically adjust the ranking logic to reflect real-world conditions. This is especially useful for attributes that frequently change, such as product availability, or real-time pricing.

    This capability is currently available to all customers as a public beta. Please contact your account representative if you would like access. Learn how to use 51黑料不打烊 Experience Platform data for decisioning

Define criteria using the formula builder ranking-select-criteria

With an intuitive interface, you can fine-tune decisioning by adjusting AI scores (propensity), offer value (priority), contextual levers, and external profile propensities 鈥 individually or in combination 鈥 to optimize every interaction.

To define criteria directly from the interface, follow the steps below.

  1. In the Criterion 1 section, specify the decision items that you want to apply a ranking score to by doing the following:

    {width="70%"}

  2. Optionally, you can specify additional elements to refine the matching conditions for your criteria to be true.

    {width="80%"}

    For example, you defined Criterion 1 such as the Weather custom attribute Equals the warm condition. Additionally, you can add another condition such as if the first condition is met and if the temperature exceeds 75 degrees at the time of the request, then Criterion 1 is true.

  3. Create an expression that will assign a ranking score to the decision items that meet the condition defined above. You can reference any of the following:

    • the score that came out of the AI model that you optionally selected in the Details section above;
    • the decision item鈥檚 priority, which is a value manually assigned when creating a decision item;
    • any attribute that might live on the profile, such as any externally derived propensity score;
    • a static value that you can assign in a free format;
    • any combination of all the above.

    {width="70%"}

    note note
    NOTE
    Click the icon next to the field to add predefined variables.
  4. Click Add criterion to add one or more criteria as many times as needed. The logic is as follows:

    • If the first criterion is true for a given decision item, it takes precedence over the next ones.
    • If not true, the decisioning engine moves on to the second criterion, and so on.
  5. In the last field, you can build an expression that will be assigned to all decision items that do not meet the above criteria.

    {width="70%"}

  6. Click Create to complete your ranking formula. You can now select it from the list to view its details, and edit or delete it. It is ready to be used in a selection strategy to rank eligible decision items.

Ranking formula example

Consider the example below:

{width="80%"}

If the decision item鈥檚 region (custom attribute) equals the profile鈥檚 geographical label (profile attribute), the ranking score expressed here (which is a combination of the decision item priority, the AI model score and a static value) will be applied to all decision items meeting that condition.

Use the code editor ranking-code-editor

To express ranking formulas in PQL syntax, switch to the code editor using the dedicated button on top right of the screen. For more on how to use the PQL syntax, refer to the dedicated documentation.

CAUTION
This action will prevent you from reverting back to the default builder view for this formula.

You can then leverage profile attributes, context data, and decision item attributes.

For example, you want to boost the priority of all offers with the 鈥渉ot鈥 attribute if the actual weather is hot. To do this, the contextData.weather=hot was passed in the decisioning call.

{width="80%"}

IMPORTANT
When creating a ranking formula, looking back into a previous period of time is not supported, such as adding an experience event that occurred within the last month as a component of the formula. Any attempt to include a lookback period during formula creation will trigger an error when saving it.

To leverage attributes related to your decision items in formulas, make sure you follow the correct syntax in your ranking formula鈥檚 code. Expand each section for more information:

Leverage decision items standard attributes
Leverage decision items custom attributes

Ranking formula PQL examples ranking-formula-examples

You can create many different ranking formulas according to your needs. Below are some examples.

Boost offers with certain offer attribute based on profile attribute

If the profile lives in the city corresponding to the offer, then double the priority for all offers in that city.

Ranking formula:

code language-none
if( offer.characteristics.get("city") = homeAddress.city, offer.rank.priority * 2, offer.rank.priority)
Boost offers where the end date is less than 24 hours from now

Ranking formula:

code language-none
if( offer.selectionConstraint.endDate occurs <= 24 hours after now, offer.rank.priority * 3, offer.rank.priority)
Boost offers based on the customers propensity to purchase the product being offered

You can boost the score for an offer based on a customer propensity score.

In this example, the instance tenant is _salesvelocity and the profile schema contains a range of scores stored in an array:

Given this, for a profile such as:

code language-none
{"_salesvelocity": {"individualScoring": [
                    {"core": {
                            "category":"insurance",
                            "propensityScore": 96.9
                        }},
                    {"core": {
                            "category":"personalLoan",
                            "propensityScore": 45.3
                        }},
                    {"core": {
                            "category":"creditCard",
                            "propensityScore": 78.1
                        }}
                    ]}
}
Boost offers based on context data

Journey Optimizer allows you to boost certain offers based on the context data being passed in the call. For example, if the contextData.weather=hot is passed, the priority of all offers with attribute=hot must be boosted.

note note
NOTE
For detailed information on how to pass context data, refer to this section.

Note that when using the Decisioning API, the context data is added to the profile element in the request body, such as in the example below:

code language-none
"xdm:profiles": [
{
    "xdm:identityMap": {
        "crmid": [
            {
            "xdm:id": "CRMID1"
            }
        ]
    },
    "xdm:contextData": [
        {
            "@type":"_xdm.context.additionalParameters;version=1",
            "xdm:data":{
                "xdm:weather":"hot"
            }
        }
    ]

}],
recommendation-more-help
b22c9c5d-9208-48f4-b874-1cefb8df4d76