The $ZPREVIOUS function returns the subscript of the previous local or global variable name in collation sequence within the array level specified by its argument. When $ZPREVIOUS() has an unsubscripted argument, it returns the previous unsubscripted local or global variable name in collating sequence.
The $ZPREVIOUS function provides compatibility with some other M implementations. The M Development Committee chose to implement this functionality with the optional second -1 argument of $ORDER(). Therefore, when a design requires this functionality $ORDER() has the advantage over $ZPREVIOUS of being part of the M standard.
The format for the $ZPREVIOUS function is:
    $ZP[REVIOUS](glvn)        
    
      The subscripted or unsubscripted global or local variable name specifies the node prior to which $ZPREVIOUS() searches backwards for a defined node with data and/or descendants. The number of subscripts contained in the argument implicitly defines the array level.
If $ZPREVIOUS() finds no node at the specified level before the specified global or local variable, it returns a null string.
If the last subscript in the subscripted global or local variable name is null, $ZPREVIOUS() returns the last node at the specified level.
$ZPREVIOUS() is equivalent to $ORDER() with a second argument of -1.