Segment definition data structure
The segment definition data structure is used to communicate segment rules to the API. This data structure defines the raw logic that is used to isolate the segment data. The segment definition is a hierarchical data structure of containers, functions, and boolean logic that is used to define the segment. The segment tool in the Adobe Analytics UI follows these rules and can be a useful tool for understanding how the data structure looks.
Adobe may add optional request and response members (name/value pairs) to existing API objects at any time and without notice or changes in versioning. Adobe recommends that you refer to the API documentation of any third-party tool you integrate with our APIs so that such additions are ignored in processing if not understood. If implemented properly, such additions are non-breaking changes for your implementation. Adobe will not remove parameters or add required parameters without first providing standard notification through release notes.
Terms
The following terms are used in segment definitions:
- Schema: A report suite's configuration. Identifies which dimensions and metrics are available for use within the segment. It defines the configuration for the enabled eVars, props, events, etc.
- Attribute: An entity in the schema. For example, variables/pageorvariables/evar1.
- Context: The level that the segment logic operates on. Valid values are visitors,visits, andhits. See Segment containers in the Analytics Components guide for more information.
- Row: A single record of data in a segment. Depending on the context, this can either be a record containing a visitor (contains all hits in all visits for a visitor), a single visit (contains all hits in a visit), or a single hit. The information stored in a row depends on the context setting for the container. For example, if the context is set to visitor, the row in the container contains all information about the visitor spanning all hits from all visits. To contrast, if the context is set tohits, the row only contains information related to the individual qualifying hits in the segment logic.
- Container: A collection of rows. It groups the segment logic and context together for use in calculating the rows that are assigned to the container. A container has three properties: func,context,andpred.
- Container Set: Groups containers and creates cartesian relationships between them using boolean expressions. For example, you have a container that groups visitors that have a purchase, and a second container that groups visitors who came to the website through a specific banner ad. The container set links these two containers with a boolean expression. If you use an ANDcondition, the visitor must match both expressions. If you use anORcondition, the visitor can match one or the other.
- Data Set: The collection of all records used across containers and container sets to calculate the population of the segment.
Schema Functions
Attribute functions
| Function | Description | Parameters | 
|---|---|---|
| attr | References an attribute in the schema. For example,  evar1. | namecontains the name of the attribute in the schema. | 
Event functions
| Function | Description | Parameters | 
|---|---|---|
| event | References an event from the schema. For example,  event1orrevenue. To use this, an aggregation function like 'total' must also be used. | namecontains the name of the attribute in the schema. | 
| total | Sums an event across the context resulting in a value that can be used in comparisons. | evtcontains the event to be summed. | 
| event-exists | Checks for the existence of the event in the context. | evtcontains the event to be checked. | 
| not-event-exists | Checks for the lack of the event in the context. | evtcontains the event to be checked. | 
Grouping functions
| Function | Description | Parameters | 
|---|---|---|
| segment | Holds the definition of the segment. It is the top level object. | versioncontains an array of three numbers that describes the version to use.containeris a child function that contains the definition of the segment. | 
| container | Identifies the context and defines segment logic. | contextContains the context. Valid values arevisitors,visits,hits.predContains the logic for this container. | 
| and | Groups multiple  containerobjects together. | predsContains an array of containers that define the segment logic and performs a booleanANDoperation on them. | 
| or | Groups multiple  containerobjects together. | predsContains an array of containers that define the segment logic and performs a booleanORoperation on them. | 
| without | Performs a boolean  NOTon the container provided in thepredparameter. | predThe container to perform aNOToperation on. | 
| sequence | A group of conditions that must occur in the provided order. | streamA list of ordered containers that define conditions for the segment. | 
| sequence-prefix | A list of conditions that must occur before a certain event. | streamA list of container objects defining the logic for this part of the segment.context | 
| sequence-suffix | A list of conditions that must occur after a certain event. | streamA list of container objects defining the logic for this part of the segment.context | 
| sequence-and | A group of unordered conditions that must all occur. | checkpointsA list of container objects that define the conditions. | 
| sequence-or | A group of unordered conditions. Any individual condition (or more) must occur. | checkpointsA list of containers that define conditions for the segment. | 
Available Data Comparison Functions
String functions
| Function | Description | Parameters | 
|---|---|---|
| streq | Equals | valcontains a reference to the schema.strcontains a literal value. | 
| not-streq | Not Equals | valcontains a reference to the schema.strcontains a literal value. | 
| strlt | Less Than | valcontains a reference to the schema.strcontains a literal value. | 
| strgt | Greater Than | valcontains a reference to the schema.strcontains a literal value. | 
| strle | Less Than or Equals | valcontains a reference to the schema.strcontains a literal value. | 
| strge | Greater Than or Equals | valcontains a reference to the schema.strcontains a literal value. | 
| streq-in | Match a string to any of the values in the parameter | valcontains a reference to the schema.listcontains an array of literal values. | 
| not-streq-in | Ensure a string doesn't match any of the values in the parameter | valcontains a reference to the schema.listcontains an array of literal values. | 
| contains | Ensure a string matches or contains the value in the parameter | valcontains a reference to the schema.strcontains a literal value. | 
| not-contains | Ensure a string doesn't match or contains the value in the parameter | valcontains a reference to the schema.strcontains a literal value. | 
| contains-any-of | Ensure a string contains any of the values in the parameter. Case-insensitive. | valcontains a reference to the schema.listcontains an array of literal values. | 
| contains-all-of | Ensure a string contains all of the values in the parameter. Case-insensitive. | valcontains a reference to the schema.listcontains an array of literal values. | 
| not-contains-any-of | Ensure a string doesn't contain at least one of the values in the parameter. Case-insensitive. | valcontains a reference to the schema.listcontains an array of literal values. | 
| not-contains-all-of | Ensure a string doesn't contain any of the values in the parameter. Case-insensitive. | valcontains a reference to the schema.listcontains an array of literal values. | 
| starts-with | Ensure a string starts with the value in the parameter. Case-insensitive. | valcontains a reference to the schema.strcontains a literal value. | 
| ends-with | Ensure a string ends with the value in the parameter. Case-insensitive. | valcontains a reference to the schema.strcontains a literal value. | 
| not-starts-with | Ensure a string doesn't start with the value in the parameter. Case-insensitive. | valcontains a reference to the schema.strcontains a literal value. | 
| not-ends-with | Ensure a string doesn't end with the value in the parameter. Case-insensitive. | valcontains a reference to the schema.strcontains a literal value. | 
| matches | Ensure a string matches the glob parameter. A glob parameter uses a '' character to match any sequence of characters. A literal '' is expressed with '*'. | valcontains a reference to the schema.globcontains a literal value. | 
| not-matches | Ensure a string doesn't match the glob parameter. A glob parameter uses a '' character to match any sequence of characters. A literal '' is expressed with '*'. | valcontains a reference to the schema.globcontains a literal value. | 
Numeric functions
| Function | Description | Parameters | 
|---|---|---|
| eq | Equals | valThe attribute to compare.numThe literal number being compared to. | 
| not-eq | Not equals | valThe attribute to compare.numThe literal number being compared to. | 
| gt | Greater than | valThe attribute to compare.numThe literal number being compared to. | 
| lt | Less than | valThe attribute to compare.numThe literal number being compared to. | 
| ge | Greater than or equal to | valThe attribute to compare.numThe literal number being compared to. | 
| le | Less than | valThe attribute to compare.numThe literal number being compared to. | 
| eq-any-of | Equal to any of the values provided | valThe attribute to compare.listAn array of numbers to use in the comparison. | 
| not-eq-any-of | Not equal to any of the values provided | valThe attribute to compare.listAn array of numbers to use in the comparison. | 
Existence functions
| Function | Description | Parameters | 
|---|---|---|
| exists | Tests if an attribute has been set to a value. | valThe attribute to test. | 
| not-exists | Tests if an attribute has never been set to a value. | valThe attribute to test. | 
Temporal functions
| Function | Description | Parameters | 
|---|---|---|
| ime-restriction | Used to determine if a checkpoint occurred within a given time frame. | limitLimits the event to a context. Valid values areafterorwithin.unitA unit of time. Valid values areminute,hour,day,week,month,quarter,year.countThe number of temporal units based on theunitparameter. | 
| container-restriction | Used to determine if checkpoints described in other containers have happened in a specific sequence. | limitLimits the event to a context. Valid values areafterorwithin.countSpecifies the number of events (page views, visits, days, months, etc) between two checkpoints. | 
| dimension-restriction | Used between checkpoints to specify the activity can exist in sequence between them. | limitLimits the checkpoint to a context. Valid values areafterorwithin.countSpecifies the number of events (page views, visits, days, months, etc) between two checkpoints. | 
| exclude-next-checkpoint | Ensures the next checkpoint doesn't happen between the preceding checkpoint and the subsequent checkpoint. If there is no subsequent checkpoint then the excluded checkpoint must not occur at any point after the preceding checkpoint. If there is no preceding checkpoint then the excluded checkpoint must not have occurred at any point preceding the subsequent checkpoint. | 
See Build sequential segments in the Analytics Components user guide for more information.


