formula

Usage: set formula <formula-expression>


SUMMARY

  The formula variable filters out match requests.  If you have a formula set,
then any match request not satisfying your formula is automatically declined;
you will be notified that the offer was made and rejected by your formula.  If
you make an offer that fails a player's formula, you will be given this
feedback.  A user's formula and f-variable settings are displayed using the
"variables" command.  You disable (turn off) your formula by typing "set
formula".  This will, in essence, erase your current formula setting.

  Here are some simple examples, with descriptions in [] brackets:

    blitz        [match must be blitz]
    !wild        [match must be non-wild]
    inc >= 10    [match must have an increment of 10 or higher]

  Create or modify a formula by using the "set" command.  For example, "set
formula blitz".  Special variables (f1-f9) can also be established using the
"set" command; these variables make it easier to modify your formula depending
upon your mood.


CREATING A FORMULA

  (1) Decide whether you will be changing your formula often.  If so, think
about using f-variables to make these changes easier.

  (2) Decide exactly what kinds of filters you want to have, such as type of
game, time controls, and kinds of opponents.

  (3) Review the available formula operators and pre-defined variables (listed
below) to see which ones fit your needs.

  (4) Write out your formula and f-variables on paper to make sure that their
"logic" works.

  (5) Enter the logical expressions for the f-variables and formula using the
"set" command.

  Changing your f-variables and formula follows the same procedures.


FORMULA VARIABLES

  Several variables are allowed in formula settings.  Some of these variables
hold numerical information while others are Boolean (true/false, 1/0).  Here
is a list of allowed variables, where Boolean variables are denoted by "(B)":

  The following variables are allowed in formulas:

      Variable        Description
      ------------    ---------------------------------------------------
      abuser          1 if opponent is on the abuser list; 0 otherwise (B)
      assessdraw      How many rating points you will gain/lose by drawing a
                      chess match
      assessloss      How many rating points you will lose by losing a chess
                      match
      assesswin       How many rating points you will gain by winning a chess
                      match
      blitz           1 if match is blitz in type; 0 otherwise (B)
      computer        1 if opponent is a computer; 0 otherwise (B)
      inc             Increment time for each player
      lightning       1 if match is lightning in type; 0 otherwise (B)
      maxtime(n)      The maximum time n moves will take for BOTH players
                      (in seconds) [you must supply the 'n' value]
      mymaxtime(n)    The maximum time n moves will take YOU (in seconds)
                      [you must supply the 'n' value]
      myrating        Your rating
      nonstandard     1 if the game will have different time controls for the
                      two players; 0 otherwise (B)
      private         1 if game will be private; 0 otherwise (B)
      rated           1 if game will be rated; 0 otherwise (B)
      rating          Opponent's rating
      ratingdiff      The difference between opponent's rating and your
                      rating [rating - myrating]
      registered      1 if opponent is a registered user; 0 otherwise (B)
      standard        1 if game will be standard in type; 0 otherwise (B)
      timeseal        1 if opponent has timeseal; 0 otherwise (B)
      time            Start time for each player
      untimed         1 if game will not involve the clock; 0 otherwise (B)
      wild            1 if game will be wild in type; 0 otherwise (B)

  Also, the word "minutes" is allowed after a number that is not enclosed in
parentheses (but right now, you must use "1 minutes"; the singular is not
recognized).  The word has the effect of multiplying the previous number by
60, thus turning minute-values into seconds-values -- important for the
maxtime and mymaxtime variables.  For example, "2 minutes" would yield the
value of "120".


FORMULA OPERATORS

  The following formula operators are allowed; their order of precedence in
the calculations and evaluations is listed.  Sometimes more than one set of
symbols leads to the same result.  When functions in the formula have equal
precedence, the precedence is from left to right.

  Symbol   Function                                 Precedence
  ------   -------------------------------          ----------
    !     not; negation                                  1
    -     minus [as in -20 or -variable]                 1
    *     multiplication                                 2
    /     division                                       2
    +     addition                                       3
    -     subtraction                                    3   
    <     less than                                      4
    <=    less than or equal to [ =< also works]         4
    >     greater than                                   4
    >=    greater than or equal to [ => also works]      4
    =     equals [ == also works]                        5
    !=    not equals  [ <> also works]                   6
    &     and  [ && also works as does 'and']            7
    |     or   [ || also works as does 'or']             8

  Parentheses () are allowed in formulas and function as they do in numerical
equations: expressions within parentheses are evaluated first.  You can use
the pound sign '#' after your settings to provide comments and reminders to
yourself.  NOTE: The program divides by a fudge factor of .001 instead of
dividing by 0.


USER-DEFINED FORMULA VARIABLES (f-variables)

  F1 through f9 are user-defined formula variables changed by using the "set"
command.  These variables can return either numerical or Boolean results. 
They make it easy to change one part of your formula without retying the whole
thing, or to adjust your formula depending on your mood.  For example, if your
various f-variables were ...

      f1  rated & time=5 & inc=0   # rated 5 minute games
      f2  ratingdiff
      f3  maxtime(40) >= 2*8minutes   # at least 8 mins each for 40 moves
      f4  f2>400   # I want a REAL fight
      f5  !abuser
      f6  standard | (ratingdiff<200 & blitz)

... then, depending on your mood, you could type one of the following:

      set formula f1 & f5   # rated 5 min. games only
      set formula f2 > -100   # long games, decent competition
      set formula f1 & !f4
-or-  set formula f2 >= 0 | blitz

  You define an f-variable using the "set" command.  With respect to the above
examples, you would type such lines as ...
 
  set f2 ratingdiff
  set f4 f2>400   # I want a REAL fight
  set f5 !abuser

***  Special Note  ***
Be careful how you write the f-variables.  Make sure they have the proper
sequence.  For example, f5 can refer to f2 but f5 cannot refer to f8.


MAXTIME EXAMPLE

  Using maxtime sets the expected total time for the game.  If your formula
(or f-variable) included the following expression ...

      maxtime(30) <= 10 minutes

... this would allow no more than 10 minutes total time for the first 30 moves
of the game (5 minutes for each player, or any other combination).  


CREDITS:  Formula program for FICS written by Dave Herscovici (hersco)


See Also:  assess  blitz  lightning  match  timeseal  variables 

[Last modified: December 17, 1995 -- Friar]