Quality Stage Pattern-Action Reference
Quality Stage Pattern-Action Reference
Version 8
Pattern-Action Reference
SC18-9926-00
WebSphere QualityStage
®
Version 8
Pattern-Action Reference
SC18-9926-00
Note
Before using this information and the product that it supports, be sure to read the general information under “Notices and
trademarks” on page 49.
The concepts of pattern matching and the reasons for matching is required to obtain correct
standardization. If all elements of an address are uniquely identified by keywords, then address
standardization is simplified.
A Pattern-Action file contains all the standardization rules which are the actions to execute provided by a
given pattern of tokens. Pattern-Actions files are ASCII files that you can create or update using any
standard text editor.
The Pattern-Action file consists of a series of patterns and associated actions. After the source record is
separated into tokens and classified, the patterns are executed in the order they appear in the file. A
pattern either matches the source record or it does not match. If it matches, the actions associated with
the pattern are executed. If not, the actions are skipped. Processing then continues with the next pattern
in the file.
These are referred to in the actions as [1], [2], [3], and [4]. The unknown class (?) refers to one or more
consecutive unknown alphabetic words. This simplifies pattern construction since names like MAIN,
CHERRY HILL, and MARTIN LUTHER KING all match to a single ? operand.
You can use spaces to separate operands. For example, the following two patterns are equivalent:
^|D|?|T
^ | D | ? | T
You can add comments by preceding them with a semicolon. An entire line can be a comment line by
specifying a semicolon as the first non-blank character. For example:
;
;Process standard addresses
;
^ | D | ? | T ; 123 N MAPLE AVE
You can refer to fields by enclosing the two-character column identifier in braces. For example, {SN}
refers to the street name column (SN) of the column identifier defined in the dictionary definition file for
this rule set.
Pattern matching for an individual pattern line stops after the first match is found. A single pattern
cannot produce multiple matches. For example, the following input record shows that the pattern ^|?|T
matches to 123 MAPLE AVE but not to 456 HILL PLACE.
123 MAPLE AVE & 456 HILL PLACE
These are straightforward and do not require much further explanation. Hyphens and slashes can occur
in the patterns. For example:
123 ½ matches to ^ | ^ | / | ^
Parsing parameters
The standardization process begins by separating all elements of an address into tokens. Each token is a
word, a number, or a mixture separated by one or more spaces.
There are parsing parameters that define what constitutes a token or operand as defined in the
Pattern-Action file. For example, you might want to strip periods from the input records. Thus, N.W. and
NW are both considered to be a single token NW. A hyphen separates words and is considered to be a
token in itself. For example, 123-456 has three tokens: 123, the hyphen (-), and 456.
Spaces are separate tokens. They are also stripped from the input. For example, 123 MAIN ST consists of
three tokens: 123, MAIN, and ST.
You can override the default assumptions by specifying one or both of the following statements:
v STRIPLIST. Removes any character in the list.
v SEPLIST. Uses any character in the list to separate tokens
Any character that is in both lists separates tokens but does not appear as a token itself. The best
example of this is a space. One or more spaces are stripped but the space indicates where one word ends
and another begins. The space character should be included in both SEPLIST and STRIPLIST.
If you want to include STRIPLIST and SEPLIST, put them as the first set of statements in your .pat file,
preceded with a \PRAGMA_START, and followed by a PRAGMA_END. For example:
\PRAGMA_START
STRIPLIST " -"
SEPLIST " ,"
\PRAGMA_END
In this example, the space is in both lists. Hyphens are stripped so that STRATFORD-ON-AVON is
considered to be STRATFORDONAVON. The comma separates tokens so that the city name and state can
be found (SALT LAKE CITY, UTAH). Any other special characters are classified as a special type.
Each rule set can have its own lists. If no list is coded for a rule set, the following default lists are used:
SEPLIST: " !?%$,.;:()-/#&" STRIPLIST: " !?*@$,.;:\\’’"
2 Pattern-Action Reference
When overriding the default SEPLIST and STRIPLIST, do not cause collisions with the predefined class
meanings because the class of a special character changes if it is included in the SEPLIST.
If a special character is included in the SEPLIST and not in the STRIPLIST, the token class for that
character becomes the character itself.
For example, ^ is the numeric class specifier. If you add this character to SEPLIST and not to STRIPLIST,
any token consisting of ^ is given the class of ^ . This token would next match to a numeric class (^) in a
Pattern-Action File.
Note that the NULL class (0) is not included in this list. The NULL class is used in the classification table
or in the RETYPE action to make a token NULL. Since a NULL class never matches to anything, it is
never used in a pattern.
Take care when specifying SEPLIST and STRIPLIST entries. For example, to recognize the ampersand as a
single token, include it in SEPLIST but not in STRIPLIST. If the backslash is in SEPLIST, its class is \. If a
backslash is used in a pattern, then it must have an escape character and this appears in a pattern as a
double backslash (\\).
The input processor concatenates all the formats together (with implied spaces between each format) to
create one large field. It is this field that receives a token and is compared to the patterns.
6 Pattern-Action Reference
The $ specifier is used to make sure no tokens are left in the field after the pattern. For example, to match
to city, state and postal code, you need to make sure that no tokens follow the postal code. For example,
the following pattern matches any numeric token and in particular, the first numeric token encountered:
*^
However, the following pattern matches a number only if it is the last token:
*^ | $
This automatically recognizes the postal code and avoids matching to house numbers, numeric streets,
and so on. The asterisk (*) is a positioning specifier and means that the pattern is searched until there is a
match or the entire pattern is scanned.
The number 1 represents the first word, the number 2 represents the second, the number –1 represents
the last word, and the number –2 represents the next to last word. If the word referenced does not exist,
the pattern does not match. If you are processing company names and only wanted the first word, a
company name like JOHNSON CONTROLS CORP matches to the following patterns (assume CORP is in
the classification table as a type C).
Another good use for the subfield operand is processing address suffixes. For example, if the input
address is 123-A MAIN ST, the following pattern causes the following match:
^ | - | ?
[1] = 123
[2] = -
[3] = A MAIN
You probably do not want this result since both A and MAIN are part of the unknown token. However,
the following pattern causes the following match:
^ | - | 1
[1] = 123
[2] = -
[3] = A
The following pattern and actions can be used to process the address suffix:
^ | - | 1 \ 123-A MAIN ST
COPY [3] {HS}
RETYPE [2] 0
RETYPE [3] 0
This pattern filters out the house address suffix by copying it to the appropriate field and retyping it to
be a NULL token (and similarly retyping the hyphen) to remove them from consideration by any further
patterns in the file.
The + matches to the word CHERRY; the string HILL SANDS to ?; the –1 to SANDS. The operand [1] is
CHERRY and operand [2] is SANDS.
If you have the address 123 - A B Main St, you can use the following pattern:
^ | - | (1:2) COPY [3] {HS} RETYPE [2]0 RETYPE [3] 0
This pattern results in A and B being moved to the {HS} (house number suffix) field. This pattern also
retypes A and B to NULL tokens (and similarly retyping the hyphen) to remove them from consideration
by any further patterns in the file.
The class ** matches all tokens. For example, if you use a pattern of **, you match 123 MAIN ST and 123
MAIN ST, LOS ANGELES, CA 90016, and so on. The following pattern matches to all tokens before the
type (which can be no tokens) and the type:
** | T
Thus, 123 N MAPLE AVE matches with operand [1] being 123 N MAPLE and operand [2] being AVE.
It is important to note that no tokens are required to precede the type. AVENUE also matches this pattern
with operand [1] being NULL.
In the following pattern, the ** refers to all tokens between the numeric and the type:
^ | ** | T
You can specify a range of tokens for an ** operand. For example, the following pattern matches a
numeric followed by at least two nonstreet-type tokens followed by a street type:
^ | ** (1:2) | T
Operand [2] consists of exactly two nonstreet-type tokens. This matches 123 CHERRY TREE DR, but not
123 ELM DR. Only one token follows the number. You can specify ranges from a single token, such as
(1:1), to all the tokens, such as (1:–1).
8 Pattern-Action Reference
The pattern **(1:1) results in much slower processing time than the equivalent & to match to any single
token. However, you do not want to use & in a pattern with **, such as ** | &, because the first token
encountered is used by &. Value checks or appropriate conditions applied to using & with ** can make
sense. For example:
** | & = "123", "ABC"
For the patterns documented so far, the pattern had to match the first token in the field. For example, the
following pattern matches MAPLE AVE and CHERRY HILL RD, but does not match 123 MAPLE AVE,
because a number is the first token:
? | T
You can use floating specifiers to scan the input field for a particular pattern. The asterisk (*) is used to
indicate that the class immediately following is a floating class.
If you have apartment numbers in the address, you might want to scan for them, process them, and
retype them to NULL so that other patterns can process the address without having an apartment
number in the string. For example, addresses, such as 123 MAIN ST APT 34 or 123 # 5 MAIN ST, match to
the pattern:
* M | ^
The * M operand examines tokens until a multi-unit class token is found. A pattern of M | ^ would not
match the addresses above because the first token is the house number. The asterisk indicates to scan the
pattern forward until a class M token followed by a numeric is found. The following pattern and actions
filter out the apartment number information:
*M | ^
COPY_A [1] {UT}
COPY [2] {UV}
RETYPE [1] 0
RETYPE [2] 0
Retyping these fields to NULL removes them from consideration by any patterns later in the
Pattern-Action file.
Floating positioning specifiers avoid the problem of having to enumerate all combinations of possibilities.
For example, without floating patterns, you need individual patterns to handle cases like:
123 MAIN ST APT 5
123 N MAIN ST APT 5
123 N MAIN APT 5
With floating patterns, they can all be processed with the single pattern * M | ^.
Floating positioning specifiers operate by scanning a token until a match is found. For example, using the
above pattern and action to filter out the apartment information, the address 123 N Main Apt 5 is
processed by:
v Testing 123, which is not a match to * M | ^
v Testing N, which is also not a match
v Testing MAIN, not a match
v Testing APT, which matches M
v Testing the token following the matched token (which is 5) and does match ^
Note: There can only be one match to a pattern in an input string. After the actions are processed,
control goes to the next pattern, even though there may be other matches on the line.
The asterisk must be followed by a class. For example, the following operands are valid with a floating
positioning specifier followed by a standard class:
* M
* ?
* ^
There can be more than one floating positioning specifier in a pattern. For
example, the following operands match to JOHN DOE 123 CHERRY HILL NORTH RD:
*^ | ? | *T
Operand [1] is 123. Operand [2] is CHERRY HILL. Operand [3] is RD. NORTH is classified as a
directional (D) so it is not included in the unknown string (?).
This is useful for removing items that appear at the end of a field, such as postal code, state, and
apartment designations.
The reverse floating positioning specifier must only appear in the first operand of a pattern, since it is
used to position the pattern. For example, if you wanted to find a postal code and you have given the
state name the class S, the following pattern scans from right to left for a state name followed by a
number:
#S | ^
If you have an input string CALIFORNIA 45 PRODUCTS, PHOENIX ARIZONA 12345 DEPT 45, the right
to left scan positions the pattern to the ARIZONA. The number following causes a match to the pattern.
If no match is found, scanning continues to the left until a state followed by a number is found. If you
are limited to the standard left-right floating positioning specifier (*S | ^), the CALIFORNIA 45 is
incorrectly interpreted as a state name and postal code.
Sometimes it is necessary to position the pattern matching at a particular operand in the input string.
This is handled by the %n fixed position specifier. Examples of the fixed position specifier are:
The positions can be qualified by following the %n with a token type. Some examples are:
10 Pattern-Action Reference
%-1^ Matches to the last numeric token
%3T Matches to the third street type token
%2? Matches to the second set of two or more unknown
alphabetic tokens
You can use the fixed position specifier (%) in only two ways:
v As the first operand of a pattern
v As the first and second operands of a pattern
The following pattern is allowed and is positioned to the third leading alphabetic token following the
second numeric token if such a token exists:
%2^ | %3<
The fixed position specifier treats each token according to its class. The following examples illustrate
using the fixed position specifier for the input field:
John Doe
123 Martin Luther St
Salt Lake
The position specifier does not continue scanning if a pattern fails to match (unlike * and #).
The following pattern matches the 789 S in the string 123 A 456 B 789 S:
%3^ | D
That same pattern does not match 123 A 456 B 789 C 124 S because the third number (789) is not
followed by a direction.
The following pattern language syntax shows how to use the negative to improve matching:
The following example matches to SUITE 3, APT GROUND but not to SUITE CIRCLE:
* M | !T
This pattern matches to RT 123, but not to RT 123 MAPLE AVE because an unknown alphabetic character
follows the numeric operand.
You can combine the negation class with the floating class (*) only at the beginning of a pattern. For
example, when processing street addresses, you might want to expand ST to SAINT where appropriate.
For example, change 123 ST CHARLES ST to 123 SAINT CHARLES ST, but do not convert 123 MAIN ST
REAR APT to 123 MAIN SAINT REAR APT. You can use the following pattern and action set:
*!? | S | +
RETYPE [2] ? "SAINT"
The previous example requires that no unknown class precede the value ST because tokens with this
value have their own class of S.
12 Pattern-Action Reference
Chapter 3. Conditional Patterns
When standardizing addresses, some addresses require that conditions be attached to pattern matching.
Providing conditional values in patterns allows correct processing of problem cases.
Alphabetic values must be in double quotes. A condition to test for the presence of a token with value
MAPLE followed by a street type is:
*? = "MAPLE" | T
If the word SOUTH is in the classification table, you can test explicitly for SOUTH using D = ″SOUTH″
or for any direction with the standard abbreviation S using D = ″S″ for the operand.
You enter numeric values without quotes. The following pattern-action set matches to 1000 MAIN but not
to 1001 MAIN.
* ^ = 1000 | ?
The equality operator (=) tests both the standardized abbreviation (if the token is found in the .cls file
and has an abbreviation) and the original token value for equality to the operand. Two additional
operators are available for testing equality to the abbreviation only or the original token value only. These
are:
For example, to properly handle AVE MARIA LANE, test for equality with the original token value:
*T =T= "AVE" | +
RETYPE [1] ?
This makes sure that AVE was actually coded and not another value that maps to the same abbreviation
leaving input of AVENUE MARIA unchanged. Similarly, use =A= if you only want a test on the
abbreviation.
Numeric series can be represented in the same manner, except without quotation marks. Optionally, you
can use the abbreviation equality operator =A= or the original value operator =T=, such as:
T =A= "RD", "AV", "PL"
T =T= "RD", "AV", "PL"
For example, you want to test a number to see if it is one of a series of postal codes. You can first prepare
an ASCII file with one line for each postal code. As an illustration, this file is named postcode.tbl and
looks as follows:
90016
90034
90072
90043
...
A pattern matching city, state, and postal code might look like:
? | S | ^ = @postcode.tbl
This matches to cases, such as LOS ANGELES CA nnnnn. If the numeric operand is in the list, the pattern
matches; otherwise it does not. LOS ANGELES CA 90016 matches, but CHICAGO IL 12345 does not
because the postal code is not in the table.
The table file name can contain complete or relative path information, including an environment variable.
If a rule set has a path specified on a command line, that path is assumed for value files used in that
Pattern-Action file for the rule set and the path cannot be specified a second time.
The dictionary field contents can also be tested against tables of values:
^ | T | {SN} = @strtname.tbl
If the dictionary field contents are not pattern operands, the test against a table of values must follow all
pattern operands, including an end-of-field operand. The following example is not valid, since a pattern
operand follows the table test:
^ | {SN} = @strtname.tbl | T
Conditional expressions
The conditional expression is enclosed in brackets immediately following the pattern operand.
If simple values or tables of values are not sufficient to qualify pattern matching, you can use conditional
expressions. These expressions have the following format:
operand [conditional expression]
A simple conditional expression consists of an operand, a relational operator and a second operand. The
following are the relational operators:
14 Pattern-Action Reference
=A= Abbreviation is equal to
=T= Original token is equal to
<= Original token is less than or equal to
>= Original token is greater than or equal to
!= Abbreviation or original token is not equal to
!=A= Abbreviation is not equal to
!=T= Original token is not equal to
The city, state, and postal code example best illustrates this concept. If you want the pattern to match
only when a city and state are present and the postal code is greater than 50000, you can use:
? | S | ^ [{} > 50000]
The pattern operands in the above example have the following meaning:
When character literals are in an equality test, the standard abbreviation is tested if one is available. If
this fails, the original input is tested. The following example compares the abbreviation of the current
operand (RD) to the literal RD:
T [ {} = "RD" ]
This example compares the entire input operand to the literal (since it fails to compare to the
abbreviation):
T [ {} = "ROAD" ]
This example compares only the abbreviation of the current operand to RD:
T [ {} =A= "RD"]
This example compares the original value of the token to ROAD and not to the abbreviation:
T [ {} =T= "ROAD"]
When comparisons (other than the equality operators) are specified, as in the following example, the
original input is used rather than the abbreviation:
T [ {} <= "RD" ]
This is true for any comparison to a literal value. If the original value is RD, the result is true, but, if the
original value is ROAD, the result is false.
Sometimes you need to test a value placed in the dictionary field from an earlier process or from a
pattern-action set that was previously executed. This can be accomplished by specifying the field
identifier enclosed in braces.
For example, you have two streets named EAST WEST HIGHWAY. In postal codes 20100 to 20300, the
name of the street is EAST WEST, and in postal codes 80000 to 90000, WEST is the name of the street and
EAST is the direction. If the postal code field is filled in by an earlier process and named {ZP}, you can
use the following pattern-action sets:
^ | D = "E" | D = "W" | T = "HWY" | [ {ZP} >= 20100 & {ZP} <= 20300 ]
COPY [1] {HN} ; move house number to {HN} field
COPY [2] temp ; concat EAST WEST and move
CONCAT [3] temp ; to street name field
COPY temp {SN}
COPY_A [4] {ST} ; move HWY to street type field
^ | D = "E" | D = "W" | T = "HWY" | [ {ZP} >= 80000 & {ZP} <= 90000 ]
COPY [1] {HN} ; move house number to {HN} field
COPY_A [2] {PD} ; move EAST to direction
COPY [3] {SN} ; move WEST to street name
COPY_A [4] {ST} ; move HWY to street type field
In this pattern, the operand [{ZP} >= 20100 & {ZP} <= 20300] states:
16 Pattern-Action Reference
{ZP} The value in the postal code field
>= is greater than or equal to
20100 the number 20100
& and
{ZP} the value in the postal code field
<= is less than or equal to
20300 the number 20300
The logical operator & is used to connect two conditional expressions. Note that the condition is placed
in a separate operand. It can also be placed in the operand for HWY; for example:
^ | D = "E" | D = "W" | T = "HWY" [ {ZP} >= 80000 & {ZP} <= 90000 ]
These two forms are identical in function. However, the first form is easier to read because the conditions
are placed in separate pattern operands.
When conditions only reference dictionary field contents (and not any pattern operand), as in the above
example with {ZP}, the condition must follow all pattern operands. The following example is not valid
since the second operand does not reference an input field and a third operand (T) follows the condition:
^ | [{ZP} = 80000] | T
If you use in a condition a dictionary field name that is not defined in the dictionary definition file, any
test on its value always returns FALSE. If you are testing for NULL contents, the test returns TRUE; for
example:
{ZZ} = ""
This facility allows use of the same general Pattern-Action Files on projects which dispense with certain
fields (as opposed to aborting the program with an invalid field error).
Numeric constants are referenced to by coding a number. The following pattern operand matches on a
number equal to 10000:
^ [{} = 10000]
Negative numbers and decimal points are not permitted in numeric constants. The following example
matches to the text MAIN:
? [ {} = "MAIN" ]
If an unknown operand (?) is specified, multiple words are concatenated to a single word. To match to
CHERRY HILL, use the following pattern:
? [ {} = "CHERRYHILL" ]
You can use any of the relational operators for character strings. The following example matches on all
strings starting with MA or greater, including MA, MAIN, NAN, PAT, but not ADAMS, M, or LZ:
The equality (=) is tested on the abbreviation for the operand first if one exists, and then on the full
operand. The other relational operators test on the full operand and not the abbreviation.
You can define variables to which you assign specific values by using the actions. You can test variables
for specific values within conditions. Variables must be named according to the following conventions:
v The first character must be alphabetic.
v The name cannot exceed 32 characters.
After the first alphabetic character, you can use any combination of alphanumerical characters or the
underline (_).
For example, if you set the variable postcode to the postal code, you can test to see if the post code is
12345 as follows:
[postcode = 12345]
This type of condition can be a separate pattern operand or combined with a standard class. For example,
the following two patterns produce identical results:
^ | [postcode = 12345]
^ [postcode = 12345]
If a user variable is set to a numeric value, its type is numeric. If it is set to a literal value, its type is
character.
If a condition only references variables or dictionary fields, and not current input operands, the condition
must follow all operands. The following example is not valid since the second operand does not reference
an input field and a third operand follows:
^ | [postcode = 12345] | T
Operand length
LEN represents the length of an operand.
A special LEN qualifier is available. You can use the expression in one of the following three ways:
For example, if you want to search for a nine-digit postal code of 12345-6789, check for a five digit
number followed by a hyphen and a four digit number; for example:
^ [ {} LEN = 5] | - | ^ [{} LEN = 4]
If the numerics do not match the length, the pattern does not match.
Similarly to test the length of a variable, the following pattern matches if the variable contains five
characters:
? [ temp LEN = 5]
Finally, to test the length of a dictionary field, use the two character field identifier within braces:
18 Pattern-Action Reference
[ {SN} LEN = 20 ]
Any trailing blanks are ignored in the calculation of the length. Leading blanks are counted. For example,
if a user variable or a dictionary field was set to ″ XY″ (2 leading spaces), the length of either is 4.
Operand template
The picture defines how the numeric and alphabetic characters are distributed.
In some cases, you must test for special formats. The PICT (picture) qualifier is available to accomplish
this. Consider the case of Canadian postal codes. These are of the form character-number-character
(space) number-character-number; for example, K1A 3H4. The PICT qualifier is used to represent these
sequences:
@ [{} PICT = "cnc"] | @ [{} PICT = "ncn"]
The @ (at sign) matches to a complex type (mixed numeric and alphabetic characters).
The English postal codes use the form character-character-number (space) number-character-character; for
example, AB3 5NW.
< [{} PICT = "ccn"] | > [{} PICT = "ncc"]
Only the equality (=) and inequality (!=) operators can be used with PICT comparisons.
Operand substring
A special form is provided in the patterns to test a portion of an operand.
These portions are called substrings. The following forms are valid:
The (beg:end) specifies the beginning and ending character to extract. The first character in the string is 1,
the last character is –1, and so on.
For example, German style addresses have the street type indicated in the same word as the street name.
Thus, HESSESTRASSE means HESSE STREET. The substring form can be used to test for these suffixes.
Consider an input address of HESSESTRASSE 15. The following pattern matches to all words ending in
STRASSE that are followed by a numeric:
+ [{} (-7:-1) = "STRASSE"] | ^
+ Addition
– Subtraction
* Multiplication
/ Division
% Modulus
Arithmetic is limited to one operation per expression. Parentheses are not permitted. The modulus
operation is the remainder of an integer division. For example, x % 2 is zero if the number is divisible by
two. It is one if the number is odd.
An arithmetic expression is
left-arithmetic-operand arithmetic-operator right-arithmetic-operand
Even numbers are divisible by two, thus the house number modulo two is zero. The arithmetic
expression appears on the left side of the relational operator (the equal sign).
The following is a conditional expression to see if the current operand divided by three is greater than
the contents of variable temp:
^ [{} / 3 > temp]
Again, note that the field references and the arithmetic expression are to the left of the relational operator.
Other examples are:
[ temp * temp2 > temp3 ]
[ {ZP} + 4 > 12345]
20 Pattern-Action Reference
Combining conditional expressions
You can combine conditional expressions using logical operators.
& AND
| OR
Note: The OR operator is inclusive, if part of the statement is TRUE, the result is TRUE.
To test for even numbered houses, and for half of the value in temp to be greater than 50, and with a
postal code greater than 12345:
^ [{} % 2 = 0 & temp / 2 > 50 & {ZP} > 12345]
Parentheses are not permitted. All operations are executed left to right. Within a single bracket-delimited
condition, AND and OR operators cannot be mixed. An error message is printed if such a case is
encountered. Operator precedence can be obtained by using separate pattern operands if possible. The
arithmetic expression ((a | b) & (c | d)) can be represented by:
[a | b] | [c | d]
The vertical lines (|) within the brackets are logical OR operations, and those outside the brackets are
operand separators. In the previous example, a, b, c, and d represent conditional expressions.
Each operand of a pattern, separated by a vertical line, has an operand number. For example, the
following pattern has three operands [1], [2], and [3]:
^ | ? | T = "RD"
Any action referring to a field that is not defined in the dictionary definition file is ignored.
Copying information
The COPY action copies information from a source to a target.
Type Description
operand A pattern operand ([1], [2], ...)
substring operand A substring of the pattern operand
mixed operand Leading numeric or character subset
user variable A user-defined variable
field identifier A key reference ({SN}, ...)
formatted field A rule set reference ({CITY}, {STATE} ...)
literal A string literal in quotes (″SAINT″)
constant A numeric value
Type Description
field identifier A key reference ({SN}, ...)
user variable A user-defined variable
For example, an address pattern that matches to 123 N MAPLE AVE is:
^ | D | ? | T
The COPY_A action copies the standardized abbreviation to the dictionary field rather than the raw
value. A single COPY from a question mark (?) operand, street name in this example, copies all words of
the street name to the dictionary field. The words are concatenated together. Similarly, a single COPY
from a double asterisk (**) operand copies all tokens within the range of the asterisks with no intervening
spaces.
Copying substrings
A substring of an operand was copied by using the substring operand form.
The simplest form of the COPY action is copying an operand to a dictionary field value. For example:
COPY [2] {SN}
The substring operand only operates on standard operands or user variables. The form is:
COPY source(b:e) target
The b is the beginning column of the string and the e is the ending column. The following example
copies the first character (1:1) of operand 2 to the street name field:
COPY [2](1:1) {SN}
The following example copies the second through fourth characters of the contents of the variable temp
to the {SN} field:
COPY temp(2:4) {SN}
You can use a negative one (–1) to indicate the last character. A negative two (–2) indicates the next to
last character, and so on. The following example copies the last three characters of operand 2 to the street
name field:
COPY [2](-3:-1) {SN}
These specifiers can be used for standard operands or for user variables.
For example, with the address 123A MAPLE AVE, you want the numbers 123 to be recognized as the
house number and the letter A to be recognized as a house number suffix. This is accomplished with:
24 Pattern-Action Reference
> | ? | T
COPY [1](n) {HN}
COPY [1](-c) {HS}
COPY [2] {SN}
COPY_A [3] {ST}
EXIT
Note that the first operand () is the appropriate class (leading numeric). These leading and trailing
specifiers are mostly used with the OR < operands, but the following actions can be used to put XYZ into
the street name field from the user variable tmp2:
COPY "456XYZ" tmp2
COPY tmp2(-c) {SN}
A user variable can be the target and the source of a COPY. For example:
COPY [1] temp
COPY "SAINT" temp
COPY temp1 temp2
COPY temp1(1:3) temp2
The first line copies operand 1 to a variable named temp. The second line copies the literal ″SAINT″ to the
variable temp. The third line copies the contents of variable temp1 to temp2. The fourth line copies the first
three characters of temp1 to temp2.
User variables can consist of 1 to 32 characters where the first character is alphabetic and the other
characters are alphabetic, numeric, or an underscore (_) character.
User variables are most often used with the CONCAT action to form one field. For example, in the string
EAST WEST HWY, the name of the street is EAST WEST. You can use the following pattern and actions:
^ | D =T= "EAST" | D =T= "WEST" | T
COPY [1] {HN}
COPY [2] temp
CONCAT [3] temp
COPY temp {SN}
EXIT
This pattern tests for the specific directions EAST and WEST. After the house number is copied, the
second operand is copied to the user variable temp. The contents of temp is now EAST.
Note that the original string and not the abbreviation is copied. COPY copies the original operand
contents, while COPY_A copies the abbreviation. The next line concatenates the second direction WEST to
the variable temp. The variable now contains EASTWEST. Finally the contents of temp is copied to the
street name field.
The following example shows dictionary columns being copied to other dictionary columns or user
variables:
COPY {HN} {HC}
COPY {HN} temp
You can use the COPY actions to copy the raw data in these columns to the dictionary columns; for
example:
COPY {CITY} {CT}
COPY {STATE} {SA}
COPY {POSTALCODE} {ZP}
Standardized abbreviations are coded for entries in the classification table for the rule set. They are not
available for the hard-wired classes, such as a number, an alphabetic unknown, and so on.
You can use the COPY_A action to copy the abbreviation of an operand to either the dictionary column
or a user variable. The following shows an example:
^ | ? | T
COPY [1] {HN}
COPY [2] {SN}
COPY_A [3] {ST}
The third line copies the abbreviation of operand three to the street type column. Similarly, the following
example copies the standard abbreviation of operand three to the variable named temp:
COPY_A [3] temp
COPY_A can include a substring range, in which case the substring refers to the standard abbreviation
and not the original token, as in COPY.
When you copy an alphabetic operand (?) or a range of tokens (**) to a dictionary column or to a user
variable, the individual words are concatenated together.
COPY_S requires an operand as the source and either a dictionary column or a user variable as a target.
For example, with the following input string:
123 OLD CHERRY HILL RD
A standard COPY produces OLDCHERRYHILL, but COPY_S can be used as shown here:
^ | ? |T
COPY [1] {HN}
COPY_S [2] {SN}
COPY_A [3] {ST}
If you use the universal matching operand, all tokens in the specified range are copied. For example,
consider removing parenthetical comments to a column named {PR}. If you have the following input
address:
123 MAIN ST (CORNER OF 5TH ST) APARTMENT 6
26 Pattern-Action Reference
you can use the following pattern to move CORNER OF 5TH ST to the column {PR}. The second action
moves the same information to the user variable temp:
\( | ** | \)
COPY_S [2] {PR}
COPY_S [2] temp
Only when copying the contents of an operand does COPY remove spaces; thus, the restriction that the
source for a COPY_S action can only be an operand. For all other sources (literals, formatted columns,
and user variables), COPY preserves spaces.
When matching under uncertainty to entries in the classification table, you might want to use COPY_C
action so that the complete token is spelled correctly rather than copying an abbreviation.
For example, if you have state name table with an entry such as:
MASSACHUSETTS MA S 800.0
If Massachusetts is misspelled on an input record (for example, Masachusets), you want to copy the
correct spelling to the dictionary column. The following action places the full correctly spelled token
MASSACHUSETTS in the proper column:
COPY_C [operand-number] {column-identifier}
For COPY_C, source can only be an operand because COPY_C uses the closest token from a classification
table.
Copying initials
The COPY_I action copies the initial character (first character of the relevant tokens) to the dictionary
column rather than the entire value. You can use COPY_I in the body of the pattern or action file or as a
POST action.
the value MAPLE puts the M into {NM}. For a multi-token alphabetic string such as John Henry Smith,
the output value depends on the target. If the target is a user variable, the output value from the COPY_I
action is JHS. If the target is a dictionary column, the output value is only J (the initial of the first word).
If you use COPY_I as a POST action, the source must be a dictionary column and the target must be a
dictionary column. You generally use COPY_I to facilitate array matching.
For example, if a company name INTELLIGENT INFORMATION SYSTEMS is distributed into dictionary
columns C1 through C5 (such that C1 contains INTELLIGENT, C2 INFORMATION, C3 SYSTEMS, and
C4 and C5 are blank) the following set of POST actions put the value IIS into the company initials
dictionary column CI.
\POST_START
COPY_I {C1} {CI}
CONCAT_I {C2} {CI}
CONCAT_I {C3} {CI}
CONCAT_I {C4} {CI}
CONCAT_I {C5} {CI}
\POST_END
Moving information
You can use MOVE to move a user variable or a dictionary column to a dictionary column.
Concatenating information
The CONCAT action and the PREFIX action provides two actions for concatenating information in the
Standardize stage.
CONCAT action
CONCAT concatenates information to a user variable or a dictionary column. The source can be an
operand, literal or user variable. For example, fractional addresses, such as ½ and ¼, can be copied to a
single column in the dictionary column using the following pattern-actions:
^ | / | ^
COPY [1] temp
CONCAT [2] temp
CONCAT [3] temp
COPY temp {HS}
If you want to copy two directions with spaces (for example: EAST WEST) into a single dictionary
column, you create the following actions:
D =T= "EAST"| D =T= "WEST"
COPY [1] temp
CONCAT " " temp
CONCAT [2] temp
COPY temp {SN}
Note: A literal with a single space is concatenated to the variable. The same results cannot be obtained
by concatenating directly into the dictionary column.
In the following example, the third line is incorrect because dictionary columns are blank-filled upon
initialization and adding another space does not recognizably change the contents of the column and
does not alter any future actions:
D =T= "EAST" | D =T= "WEST"
COPY [1] {SN}
CONCAT " " {SN}
CONCAT [2] {SN}
Columns 3 to the second to last column of the first operand is concatenated to the street name column of
the dictionary column.
CONCAT_A concatenates the standard abbreviation instead of the raw data. The source can only be an
operand. CONCAT_A allows substring ranges. However, the substring refers to the standard abbreviation
and not the original token.
28 Pattern-Action Reference
CONCAT_I concatenates the initials instead of the raw data. You can use CONCAT_I as a POST action
where the source must be a dictionary column and the target must be a dictionary column.
CONCAT_I, when not used as a POST action, allows substring ranges with the substring referring to the
initials and not the original token. In most cases, there is a single initial, but for multi-token strings, such
as John Henry Smith, the initials are JHS, and substring ranges other than (1:1) make sense.
CONCAT does not provide the ability to preserve spaces between tokens matching up to either ? or ** in
a pattern statement (such as the COPY_S action). To preserve spaces between tokens, you must use the
COPY_S action to copy the tokens to a user variable and prefixing or concatenating that user variable.
For example, to pick up attention text in an input line, you might use:
PREFIX action
The PREFIX action adds data to the beginning of a string. The source for PREFIX can be an operand, a
literal, or a user variable. The target can be a user variable or a dictionary column.
COPY "CHARLES" temp
PREFIX "SAINT" temp
Columns three to the second to last column of the first operand is prefixed to the street name column.
PREFIX_A prefixes the standard abbreviation instead of the raw data. The source must be an operand.
PREFIX_A allows substring ranges; however, the substring refers to the standard abbreviation and not the
original token.
PREFIX_I prefixes the initials instead of the raw data. You can use PREFIX_I as a POST action where the
source must be a dictionary column and the target must be a dictionary column.
PREFIX_I, when not used as a POST action, allows substring ranges with the substring referring to the
initials and not the original token. In most cases, there is a single initial, but for multi-token strings, such
as John Henry Smith, the initials are JHS, and substring ranges other than (1:1) make sense.
PREFIX does not let you preserve spaces between tokens matching up to either ? or ** in a pattern
statement such as the COPY_S action. To preserve spaces between tokens, you must use COPY_S to copy
the tokens to a user variable and the prefix or concatenate that user variable. Refer to the example
pattern-action set above.
Converting information
You use the CONVERT action to convert data according to a lookup table or a literal you supply.
The codes are converted to actual place names. You must first create a table file with two columns. The
first column is the input value and the second column is the replacement value. For example, the file
codes.tbl contains:
001 "SILVER SPRING"
002 BURTONSVILLE 800.0
003 LAUREL
...
Multiple words must be enclosed in double quotes (″″). For example, if the first token in the table
contains the code, optional weights can follow the second operand to indicate that uncertainty
comparisons might be used. In the previous example, the string comparison routine is used on
BURTONSVILLE, and any score of 800 or greater is acceptable. The following pattern converts tokens
according to the above table:
&
CONVERT [1] @codes.tbl TKN
The tokens remain converted for all patterns that follow, as if the code is permanently changed to the
text.
Convert files must not of course contain duplicate input values (first token or first set of tokens enclosed
in quotes). If duplicate entries are detected, the Standardize stage issues an error message and stops.
CONVERT considerations
A CONVERT source can be an operand, a dictionary column, or a user variable, and if the source is an
operand, it requires a third argument.
Some considerations to take into account when using the CONVERT action include:
v The source of a CONVERT can be an operand, a dictionary field, or a user variable. In the following
example, both actions are valid:
CONVERT temp @codes.tbl
CONVERT {CT} @codes.tbl
v Entire path names can be coded for the convert table file specification:
CONVERT {CT} @..\cnvrt\cnvrtfile.dat
v If the source of a CONVERT is an operand, a third argument is required:
CONVERT operand table TKN
CONVERT operand table TEMP
TKN makes the change permanent for all actions involving this record.
If TEMP is included, the conversion applies only to the current set of actions.
If the conversion must be applied both to actions further down the program and to the current set of
actions, two CONVERT actions should be specified (one using TKN for other action sets and rule sets,
and one using TEMP for other actions in the current action set).
Temporary conversion
Like the CONVERT action, there are two modes that you can specify: TEMP and TKN. The TEMP mode
is a temporary conversion in which the conversion applies only to the current set of actions. The
following example converts the suffix of the first operand according to the entries in the table suffix.tbl.
CONVERT_S [1] @suffix.tbl TEMP
30 Pattern-Action Reference
If you have an operand value of HESSESTRASSE and a table entry in suffix.tbl of:
Note that there is a space now between the words. Subsequent actions in this pattern-action set operate
as expected. For example, COPY_S copies the two words HESSE STRASSE to the target. COPY, CONCAT,
and PREFIX copy the string without spaces. For example, if our table entry is:
The result of the conversion is HESSE STR. COPY_S preserves both words, but COPY copies HESSESTR
as one word. The source of a CONVERT_P or CONVERT_S can be an operand (as in the example), a
dictionary field, or a user variable with equivalent results.
Permanent conversion
The mode of TKN provides permanent conversion, where you generally specify a retype argument that
applies to the suffix with a CONVERT_S or the prefix with CONVERT_P. For example, assume you are
using the following CONVERT_S statement:
CONVERT_S [1] @suffix.tbl TKN T
You also have an operand value of HESSESTRASSE and a table entry in suffix.tbl of:
HESSE retains its class of ? because you did not specify a fifth argument to retype the body or root of the
word, and STRASSE is given the type for the suffix, such as T, for street type. To perform further actions
on these two tokens, you need a pattern of:
? | T
You might want to retype both the prefix or suffix and the body. When checking for dropped spaces, a
token such as APT234 can occur. In this case, the token has been found with a class of < (leading
alphabetic character) and an optional fourth argument can retype the prefix APT to M for multiunit and
an optional fifth argument can retype the body 234 to ^ for numeric. In the following example, the
prefix.tbl table contains an APT entry:
CONVERT_P [1] @prefix.tbl TKN M ^
If you want to retype just the body, you must specify a dummy fourth argument that repeats the original
class.
Thus, to convert SOLANO BEACH to MALIBU SHORES, the convert table must have the following two
lines:
This might produce unwanted side effects, since any occurrence of SOLANO is converted to MALIBU
and any occurrence of BEACH is converted to SHORES.
To avoid this situation, the TEMP option for CONVERT must be used. The combined tokens are treated
as a single string with no spaces. Thus, SOLANOBEACH becomes the representation for a ? pattern
containing the tokens SOLANO and BEACH. The following entry in the CONVERT table accomplishes
the proper change:
In this convert table there must be no spaces separating the original concatenated tokens. When copying
the converted value to a dictionary field, COPY does not preserve spaces. Therefore, use COPY_S if you
need to keep the spaces.
For example, to assign a city name of LOS ANGELES to a dictionary column, you can use either of the
following actions:
COPY "LOS ANGELES" {CT}
CONVERT {CT} "LOS ANGELES"
TKN makes the change permanent for all actions involving this record, and TEMP makes it temporary
for the current set of actions.
An optional class can follow the TKN. Since converting to a literal value is always successful, the
retyping always takes place.
Such tokens can occur in German addresses, where the suffix STRASSE can be concatenated onto the
proper name of the street, such as HESSESTRASSE.
If a list of American addresses has a significant error rate, you might need to check for occurrences of
dropped spaces such as in MAINSTREET. To handle cases such as these, you can use the CONVERT_P
action to examine the token for a prefix and CONVERT_S for a suffix.
Both CONVERT_P and CONVERT_S use almost the same syntax as CONVERT. The first difference is that
you must use a convert table with these actions. The second difference is that you have an optional fifth
argument.
32 Pattern-Action Reference
CONVERT_P source @table_name TKN | TEMP retype1 retype2CONVERT_S source @table_name TKN | TEMP retype1 retype2
Argument Description
source Can be either an operand, a dictionary field, or a user
variable
retype1 Refers to the token class that you want assigned to the
prefix with a CONVERT_P or suffix with a CONVERT_S.
This argument is optional.
retype2 Refers to the token class that you assigned to the body or
root of the token if the source is an operand.
has the following result in the house number and street name fields:
123 AAVENUEBBC STRASSE
^ | + | T | + | + | T
COPY [1] {HN}
COPY [5] {SN}
COPY [6] {ST}
EXIT
results in:
123 C STRASSE
When you concatenate alphabetic characters with the pattern ?, CONVERT_P, or CONVERT_S, action
operates on the entire concatenated string for user variables, dictionary fields, and operands if the mode
is TEMP.
For operands with a mode of TKN, each token in the token table that comprises the operand is examined
individually and new tokens corresponding to the prefix or suffix are inserted into the table each time the
prefix or suffix in question is found.
The syntax for CONVERT_R is simpler than that for CONVERT since an operand is the target of the
action and the argument of TKN is assumed. Use a convert table and the tokenization process retypes
automatically:
CONVERT_R source @table_name
The intended use of CONVERT_R is for street aliases. For example, the file st_alias.tbl contains the
following entries:
OBT "ORANGE BLOSSOM TRL"
SMF "SANTA MONICA FREEWAY"
WBN "WILSHIRE BLVD NORTH"
WBS "WILSHIRE BLVD SOUTH"
The alias is expanded and its individual tokens properly classified. Using the above example, WBN is
expanded into three tokens with classes ?, T, and D. The remaining pattern and actions sets work as
intended on the new address string.
Retyping tokens
An optional token class can follow the TKN keyword.
The token is retyped to this class if the conversion is successful. If no class is specified, the token retains
its original class. The following example converts a single unknown alphabetic token based on the entries
in the three files. If there is a successful conversion, the token is retyped to either C, T, or U.
+
CONVERT [1] @cities.tbl TKN C
CONVERT [1] @towns.tbl TKN T
CONVERT [1] @unincorp.tbl TKN U
34 Pattern-Action Reference
The pattern must have the following format followed by a standard RETYPE statement referencing
operand [1]:
number*class
The number must be an integer from 0 to MAX_TOKENS (currently 40) and indicates the number of
referenced occurrences. Zero means that all occurrences should be scanned.
For example, if you processed hyphenated house numbers, like 123-45 Main St., and you want to remove
all hyphens from the tokens that remain, use the following pattern action set:
0 * -
RETYPE [1] 0
This scans for all hyphens and retypes them to NULL. If you want to retype two numeric tokens to an
unknown type with a value of UKN, you use the following pattern-action set:
2 * ^
RETYPE [1] ? "UKN"
The entire pattern is restricted to this simple format when multiple occurrences are referenced.
Retyping operands
The RETYPE action is used to change the type of an operand in the token table, optionally change its
value, and optionally change its abbreviation.
Argument Description
operand The operand number in the token table
class The new class value
variable | literal The new token value, which can be a variable or a literal
(optional)
variable | literal The new token abbreviation can be a variable or a literal
(optional)
Note: If you want to change the token abbreviation but
leave the token value as is, you can copy the token value
to a user variable and use that variable as the third
argument.
A basic concept of writing standardization rules is filtering. You can change phrases and clauses by
detecting, processing, or removing them from the token table. You can remove them by retyping them to
the NULL class (0). NULL classes are ignored in all pattern matching.
For example, if you want to process apartments and remove the number from the address, you can use
the following rule:
*M | &
COPY_A [1] {UT}
COPY [2] {UV}
RETYPE [1] 0
RETYPE [2] 0
Removing the apartment designation converts the address 123 MAIN ST APT 56 to a standard form, such
as 123 MAIN ST. An apartment followed by any single token is detected. The fields are moved to the
dictionary field and retyped to NULL, so that they would not match in any later patterns.
This set scans for a type S token (the only value for type S is ST) preceded by any token type except
unknown alphabetic character and followed by a single alphabetic word. The RETYPE action changes the
type S operand to an unknown alphabetic character (?) and replaces the text with SAINT. If the input
data is the following address:
123 ST CHARLES ST
The result corrects the ambiguity of the abbreviations for SAINT and STREET as shown in the following
example:
123 SAINT CHARLES ST
This rule matches the standard ^ | ? | T pattern after the final ST is retyped to T as is done in the
geocode rule set. The ? is used for the retype class. This is important because you want to consider
SAINT to be the same token as the neighboring unknown alphabetic tokens.
The first operand of the pattern (*!?) makes sure that ST is not preceded by an unknown alphabetic
character. This prevents the input MAIN ST JUNK from being standardized into MAIN SAINT JUNK.
A fourth operand is available for the RETYPE action to change the standard abbreviation of the operand.
If you include this operand, you must also include the token value replacement argument (third
argument). If you do not want to replace the token value, you can use the original value as the
replacement value. For example, the address ST 123 can mean SUITE 123.
If the standard abbreviation for SUITE is STE, you need to change the token abbreviation with the
following pattern-action set:
S | ^
RETYPE [1] M "SUITE" "STE"
This is interpreted in future patterns as SUITE 123 and has the abbreviation STE.
For the optional third and fourth arguments, you can use a substring range. For example, with an input
record of 8 143rd Ave and the following pattern-action set:
^ | > | T
COPY [2](n) temp
RETYPE [2] ^ temp(1:2)
the 143 is copied to the variable temp, the 14 replaces the contents of the second token, and its class
becomes numeric (^).
RETYPE reclassifies all elements of a possibly concatenated alphabetic class (?) or universal class (**), if
no subfield ranges (n:m) are specified. RETYPE reclassifies only those tokens within the subfield range if
a range is specified. For example, if you have the following input:
15 AA BB CC DD EE FF RD
^|?|T
RETYPE [2] 0 ; Sets AA to FF to NULL class
^|3|T
RETYPE [2] 0 ; Sets CC to NULL class
36 Pattern-Action Reference
^ | (2:3) | T
RETYPE [2] 0 ; Sets BB and CC to NULL class
^ | -2 | T
RETYPE [2] 0 ; Sets EE to NULL class
RETYPE operates in a similar fashion to CONVERT with a TKN argument. The values for RETYPE (class,
token value, abbreviation) are not available within the current pattern-action set and are available only
for following pattern-action sets. Consequently, a pattern or action set does not produce the desired
results and is therefore flagged as an error, as in the following example:
...
RETYPE [1] ...
COPY [1] ...
Patterning
This statement generates the pattern for the active token set.
Argument Description
Target The name of either a user variable or dictionary column
where the returned pattern will be stored
For example:
&PATTERN {IP}
In the previous example, when the PATTERN action executes, the pattern associated with all active
tokens is generated and stored in the dictionary field {IP} .
This statement performs user overrides for Domain Pre-Processor rule sets.
Recommended syntax:
OVERRIDE_P Lookup_Value @Table_Name Return_Code [ CLASS | VALUE ]
Argument Description
Lookup_Value The name of the user variable containing either a pattern
or text reference to the active token set that is to be
checked for any applicable user overrides by looking up
to the Table_Name provided
Table_Name The name of the user override table to use
Return_Code The name of either a user variable or dictionary field in
which to store the return code value
Value Description
0 (zero) (default value) No user overrides were executed because no match was
found for the specified Lookup_Value on the specified
Table_Name
1 A user override was successfully executed with no errors
For example:
OVERRIDE_P Text @USPREPIP.TBL Return VALUE
OVERRIDE_P Pattern @USPREPIP.TBL Return CLASS
The specified Lookup_Value is searched for on the specified Table_Name. If the Lookup_Value is found, the
active token set is RETYPEd using the override instructions found in the matching table entry. A return
code value is always returned and stored in the specified Return_Code.
Lookup_Value can contain either a pattern or a string of literal token values, which represents the entire
active token set.
If any syntax errors are found, the STAN execution stops and an error message is written to the log file
including the override table name, the contents of the invalid entries, and an explanation of the nature of
the errors.
For each active token there should be one corresponding domain mask in the override instruction The
domain mask is the class to use to RETYPE the corresponding token. The only valid values for a domain
mask are A, N, O, and R.
38 Pattern-Action Reference
The two primary errors to check for are:
v Invalid domain masks (not A, N, O, or R)
v Incomplete override instructions (there was not a valid instruction for each active token)
Argument Description
Lookup_Value The name of the user variable containing either a pattern
or text reference to the active token set that is to be
checked for any applicable user overrides by looking up
to the Table_Name provided.
Table_Name The name of the user override table to use.
Return_Code The name of either a user variable or dictionary field in
which to store the return code value.
[ CLASS | VALUE ] CLASS indicates that the Lookup_Value contains a pattern
reference where each token is represented by its token
class.
Value Description
0 (zero) (default value) No user overrides were executed because no match was
found for the specified Lookup_Value on the specified
Table_Name.
1 A user override was successfully executed with no
errors.
The specified Lookup_Value is searched for on the specified Table_Name. If the Lookup_Value is found, the
active token set is written to dictionary fields using the override instructions found in the matching table
entry and then RETYPEd to null. Any existing content of the dictionary field is preserved while running
the override instructions. A return code value is always returned and stored in the specified Return_Code.
The Lookup_Value can contain either a pattern or a string of literal token values, which represents the
entire active token set.
The Table_Name is a two-column STAN conversion table using the following formats:
v Pattern Override Table Format (for Domain-Specific Rule Sets)
Column 1: <[Classification for Token #1][Classification for Token #2]...>
If any syntax errors are found, the STAN execution stops and an error message is written to the log file
including the override table name, the contents of the invalid entries, and an explanation of the nature of
the errors.
For each active token there are three corresponding bytes in the override instruction. The first two bytes
must be a valid dictionary field existing in the current rule set’s dictionary file to which the
corresponding token is to be written. The third byte must be a valid data flag indicating the associated
actions to be performed on the corresponding token. The only situation where there will be fewer valid
override instructions than active tokens is when a ″move all remaining tokens″ or ″drop all remaining
tokens″ data flag is used (values 5,6,7,8, and 9 in the table below).
40 Pattern-Action Reference
Value Associated actions
4 Append the standard value of the corresponding token,
without appending a leading character space, to the
specified dictionary field (if no standard value is
available for the corresponding token then the original
value should be used)
5 Move all remaining tokens using their original values,
leaving one character space between each token, to the
specified dictionary field
6 Move all remaining tokens using their standard values,
leaving one character space between each token, to the
specified dictionary field (if no standard value is
available for any of the remaining tokens then the
original value should be used)
7 Move all remaining tokens using their original values,
with no character space between each token, to the
specified dictionary field
8 Move all remaining tokens using their standard values,
with no character space between each token, to the
specified dictionary field (if no standard value is
available for any of the remaining tokens then the
original value should be used)
9 Drop all remaining tokens
Setting margins
You can restrict pattern-action sets by setting left and right margins.
You might want to restrict pattern-action sets to ranges of input tokens. For example, if your input
consists of records each comprised of four lines, two lines of address information and zero, one, or two
lines of department or institution names, you might want to search for an address line with a number,
street name, and street type, process only that line, and retype the tokens to NULL.
If you did the same for the city, state, and postal line, you can be guaranteed that anything remaining is
department or institution names.
This type of restricted processing can be accomplished by setting left and right margins. The default
settings are: left margin is the first token and right margin is the last token. These settings can be
changed by using the SET_L_MARGIN and SET_R_MARGIN actions. Each action takes one of two
keywords followed by a number or number within square brackets. You can use the following syntax:
SET_L_MARGIN LINE number | OPERAND number
SET_R_MARGIN LINE number | OPERAND number
In this example, the patterns or action sets see only tokens that reside on line two (assuming that your
input records contain at least two lines) unless one of the following pattern-action sets again changes the
margins. When you specify the keyword LINE and you want to set a left margin, it is set to the first
token of the line. If want to set a right margin, it is set to the last token of the line.
In this example, both the left and right margins are set to operand three. Since more than one token can
comprise the token set corresponding to the unknown alphabetic type ?, the left margin is always set to
the first token of the set and the right margin is always set to the last token of the set.
The same holds true for the type **. If operand three has specified another type that can only refer to a
single token, such as ^, setting both left and right margins to operand three results in the next
pattern-action sets only seeing that single token. Of course, as with any pattern-action set, if the
associated pattern does not match to the input record, the actions are ignored and the margins are left
unchanged.
After processing is complete within the set of tokens specified by the left and right margins, you need to
reset the margins to their widest setting to reposition the other lines or tokens. Use the keywords
BEGIN_TOKEN for the left margin and END_TOKEN for the right margin:
SET_L_MARGIN OPERAND [BEGIN_TOKEN]
SET_R_MARGIN OPERAND [END_TOKEN]
It is important to note that if, after setting margins, you retype all tokens within the margins to NULL,
you have no access to any other tokens. To execute the actions that reset the margins, you must use a
pattern that does not require any token to be found. The normal method is, at the beginning of a process,
to create a condition that tests true at any point in the pattern-action sequence. Your first pattern-action
set could be:
&
COPY "TRUE" true
At some point after all visible tokens have been retyped to NULL, you can execute the margin resetting
actions using the following pattern-action sequence:
[true = "TRUE"]
SET_L_MARGIN OPERAND [BEGIN_TOKEN]
SET_R_MARGIN OPERAND [END_TOKEN]
For example, the following action computes the SOUNDEX of the street name field and place result in
the XS dictionary field:
SOUNDEX {SN} {XS}
The RSOUNDEX (reverse SOUNDEX) action is the same as the SOUNDEX action except that the
phonetic code is generated from the last nonblank character of the field and proceeds to the first. This is
useful for blocking fields where the beginning characters are in error.
The SOUNDEX and RSOUNDEX actions are used in the POST action section, so they are executed after
pattern matching is complete for the record.
POST actions must occur prior to any pattern-action sets and are preceded by the line \POST_START and
followed by the line \POST_END.
42 Pattern-Action Reference
NYSIIS coding
The NYSIIS action is used to compute the NYSIIS code of a dictionary field and move the results to
another dictionary field.
NYSIIS is an improvement over SOUNDEX. The NYSIIS action has the following format:
NYSIIS source-field target-field
For example, the following action computes the NYSIIS of the last name field and places the eight
character result in the XL dictionary field:
NYSIIS {LN} {XL}
The RNYSIIS action is reverse NYSIIS. The NYSIIS and RNYSIIS actions are used in the POST action
section, so they are run after pattern matching is complete for the record.
POST actions must occur prior to any pattern-action sets and must be preceded by the line
\POST_START and followed by the line \POST_END.
If the input record matches the pattern, the current process ends after the COPY actions (and after any
POST actions).
Calling subroutines
Subroutines are available to facilitate fast processing.
Since pattern or action sets are executed sequentially, it is fastest to test for a generic type and call a
subroutine to process that type. This is best illustrated by an example:
%1 M
CALL APTS
If a multiunit type is detected anywhere in the input, the subroutine APTS is called to process the
apartment numbers. Subroutine names are formed according to the same rules as variables names (up to
32 characters with the first being alphabetic).
Writing subroutines
A subroutine is delimited in a manner similar to the POST actions.
...
... subroutine body
\END_SUB
You can add as many \SUB and \END_SUB sets as required. The following example illustrates a rules
file organization:
\POST_START
actions
POST_END
%1 M
CALL APTS
%1 R
CALL ROUTES
...
... Additional patterns and actions
...
\SUB APTS
...
... Apartment processing patterns and actions
...
\END_SUB
\SUB ROUTES
...
... Route processing patterns and actions
...
\END_SUB
All subroutines are coded at the end of the file. The order of the subroutines themselves is unimportant.
The subroutines contain the standard pattern or action sets as found in the main rules.
Subroutines can be nested. That is, CALL actions are permitted within subroutines.
Control is returned back to the level from which a routine was called, either another subroutine or the
main program, when the \END_SUB is reached or when a RETURN action is executed.
Rejecting a record
If the REJECT action is used, it must be the only action associated with a pattern except for EXIT.
If the REJECT action is used, it must be the only action associated with a pattern except for EXIT. If the
pattern matches, the input record is written to the reject file and nothing else is done with it. The REJECT
action does not take any arguments.
44 Pattern-Action Reference
Summary of sources and targets
The following is a summary of the sources and targets allowed for all actions.
Margin setting actions have no source or target, instead they take a first argument of keyword
OPERAND/LINE and a second argument of operand number (enclosed in square brackets []) or line
number, for example:
SET_L_MARGIN LINE 5
SET_R_MARGIN OPERAND [3]
publib.boulder.ibm.com/infocenter/iisinfsv/v8r0/index.jsp
You can order IBM publications online or through your local IBM representative.
v To order publications online, go to the IBM Publications Center at www.ibm.com/shop/publications/
order.
v To order publications by telephone in the United States, call 1-800-879-2755.
To find your local IBM representative, go to the IBM Directory of Worldwide Contacts at
www.ibm.com/planetwide.
Contacting IBM
You can contact IBM by telephone for customer support, software services, and general information.
Customer support
To contact IBM customer service in the United States or Canada, call 1-800-IBM-SERV (1-800-426-7378).
Software services
To learn about available service options, call one of the following numbers:
v In the United States: 1-888-426-4343
v In Canada: 1-800-465-9600
General information
Accessible documentation
Documentation is provided in XHTML format, which is viewable in most Web browsers.
Syntax diagrams are provided in dotted decimal format. This format is available only if you are accessing
the online documentation using a screen reader.
Your feedback helps IBM to provide quality information. You can use any of the following methods to
provide comments:
v Send your comments using the online readers’ comment form at www.ibm.com/software/awdtools/
rcf/.
v Send your comments by e-mail to comments@us.ibm.com. Include the name of the product, the version
number of the product, and the name and part number of the information (if applicable). If you are
commenting on specific text, please include the location of the text (for example, a title, a table number,
or a page number).
48 Pattern-Action Reference
Notices and trademarks
Notices
This information was developed for products and services offered in the U.S.A.
IBM may not offer the products, services, or features discussed in this document in other countries.
Consult your local IBM representative for information on the products and services currently available in
your area. Any reference to an IBM product, program, or service is not intended to state or imply that
only that IBM product, program, or service may be used. Any functionally equivalent product, program,
or service that does not infringe any IBM intellectual property right may be used instead. However, it is
the user’s responsibility to evaluate and verify the operation of any non-IBM product, program, or
service.
IBM may have patents or pending patent applications covering subject matter described in this
document. The furnishing of this document does not grant you any license to these patents. You can send
license inquiries, in writing, to:
For license inquiries regarding double-byte (DBCS) information, contact the IBM Intellectual Property
Department in your country or send inquiries, in writing, to:
The following paragraph does not apply to the United Kingdom or any other country where such
provisions are inconsistent with local law: INTERNATIONAL BUSINESS MACHINES CORPORATION
PROVIDES THIS PUBLICATION ″AS IS″ WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR
IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Some
states do not allow disclaimer of express or implied warranties in certain transactions, therefore, this
statement may not apply to you.
This information could include technical inaccuracies or typographical errors. Changes are periodically
made to the information herein; these changes will be incorporated in new editions of the publication.
IBM may make improvements and/or changes in the product(s) and/or the program(s) described in this
publication at any time without notice.
Any references in this information to non-IBM Web sites are provided for convenience only and do not in
any manner serve as an endorsement of those Web sites. The materials at those Web sites are not part of
the materials for this IBM product and use of those Web sites is at your own risk.
IBM may use or distribute any of the information you supply in any way it believes appropriate without
incurring any obligation to you.
IBM Corporation
J46A/G4
555 Bailey Avenue
San Jose, CA 95141-1003 U.S.A.
Such information may be available, subject to appropriate terms and conditions, including in some cases,
payment of a fee.
The licensed program described in this document and all licensed material available for it are provided
by IBM under terms of the IBM Customer Agreement, IBM International Program License Agreement or
any equivalent agreement between us.
Any performance data contained herein was determined in a controlled environment. Therefore, the
results obtained in other operating environments may vary significantly. Some measurements may have
been made on development-level systems and there is no guarantee that these measurements will be the
same on generally available systems. Furthermore, some measurements may have been estimated through
extrapolation. Actual results may vary. Users of this document should verify the applicable data for their
specific environment.
Information concerning non-IBM products was obtained from the suppliers of those products, their
published announcements or other publicly available sources. IBM has not tested those products and
cannot confirm the accuracy of performance, compatibility or any other claims related to non-IBM
products. Questions on the capabilities of non-IBM products should be addressed to the suppliers of
those products.
All statements regarding IBM’s future direction or intent are subject to change or withdrawal without
notice, and represent goals and objectives only.
This information is for planning purposes only. The information herein is subject to change before the
products described become available.
This information contains examples of data and reports used in daily business operations. To illustrate
them as completely as possible, the examples include the names of individuals, companies, brands, and
products. All of these names are fictitious and any similarity to the names and addresses used by an
actual business enterprise is entirely coincidental.
COPYRIGHT LICENSE:
This information contains sample application programs in source language, which illustrate programming
techniques on various operating platforms. You may copy, modify, and distribute these sample programs
in any form without payment to IBM, for the purposes of developing, using, marketing or distributing
application programs conforming to the application programming interface for the operating platform for
which the sample programs are written. These examples have not been thoroughly tested under all
conditions. IBM, therefore, cannot guarantee or imply reliability, serviceability, or function of these
programs.
Each copy or any portion of these sample programs or any derivative work, must include a copyright
notice as follows:
© (your company name) (year). Portions of this code are derived from IBM Corp. Sample Programs. ©
Copyright IBM Corp. _enter the year or years_. All rights reserved.
50 Pattern-Action Reference
If you are viewing this information softcopy, the photographs and color illustrations may not appear.
Trademarks
IBM trademarks and certain non-IBM trademarks are marked at their first occurrence in this document.
Java™ and all Java-based trademarks and logos are trademarks or registered trademarks of Sun
Microsystems, Inc. in the United States, other countries, or both.
Microsoft®, Windows®, Windows NT®, and the Windows logo are trademarks of Microsoft Corporation in
the United States, other countries, or both.
Intel®, Intel Inside® (logos), MMX and Pentium® are trademarks of Intel Corporation in the United States,
other countries, or both.
UNIX® is a registered trademark of The Open Group in the United States and other countries.
Linux® is a trademark of Linus Torvalds in the United States, other countries, or both.
Other company, product or service names might be trademarks or service marks of others.
54 Pattern-Action Reference
Printed in USA
SC18-9926-00