When you specify a Groovy expression here, only the combinations that result in true will be built. In evaluating the expression, axes are exposed as variables (with their values set to the current combination evaluated).
For example, let's say you are building on different operating systems for different compilers. Assume that your slave labels are label=[linux,solaris] and you have created an axis as compiler=[gcc,cc]. Any of the following expressions will filter out cc builds on linux. Depending on how you think about this constraint, you'll probably find some more intuitive than others.
| Read "if both linux and cc, it's invalid" | !(label=="linux" && compiler=="cc") | 
| Read "for a combination to be valid, it has to be either on solaris or on gcc." | label=="solaris" || compiler=="gcc" | 
| Read "if on Solaris, just do cc" | (label=="solaris").implies(compiler=="cc") | 
In addition to the specific filtering rules based on values, one can also use a special variable "index", which can be used to sparsen the matrix.
For example, index%2==0 would cut the matrix size in half by removing one combination per every 2 combinations, in such a way that the coverage is still reasonable. Similarly, index%3!=0 would cut the matrix size into 66% by throwing away every 1 out of 3 combinations.