packages icon



 RELS(1)                                                             RELS(1)
                              February 22, 1998



 NAME
      rels - order the relevance of text documents to a phonetic search
      criteria

 SYNOPSIS
      rels [options] patterns paths ...

 DESCRIPTION
      Rels is a program that determines the relevance of text documents to a
      set of keywords expressed in boolean infix notation.  The relevance is
      determined by comparing the phonetic representation of the keywords
      with the phonetic representation of every word in a document.
      (Phonetic searching has some degree of tolerance to misspelled words.)
      The list of file names that are relevant are printed to the standard
      output, in order of relevance. The boolean operators supported are
      logical or, logical and, and logical not. These operators are
      represented by the symbols, "|", "&", and, "!", respectively, and left
      and right parenthesis, "(" and ")", are used as the grouping
      operators. The paths can be files and/or directories-if it is a
      directory, the program will recursively descend into the directory,
      searching all files and directories contained in the directory.

      For example, the command:

          rels "(directory & listing)" /usr/share/man/cat1

      (ie., find the order of relevance of all files that contain both of
      the words "directory" and "listing" in the catman directory) will list
      a few tens of files, out of the hundreds of catman files, of which
      "ls.1" is the among the most relevant-meaning that to find the command
      that lists directories in a Unix system, the "literature search" was
      reduced, on average, by about 98%, which is a considerable expediency
      in relation to browsing through the files in the directory.  Although
      this example is remedial, a similar expediency can be demonstrated in
      searching for documents in email repositories and text archives.

      Additional applications include information robots, (ie., "mailbots,"
      or "infobots,") where the disposition (ie., delivery, filing, or
      viewing,) of text documents can be determined dynamically, based on
      the relevance of the document to a set of criteria, framed in boolean
      infix notation. Or, in other words, the program can be used to order,
      or rank, text documents based on a "context," specified in a general
      mathematical language, similar to that used in calculators.

      The words in the query are case insensitive, and either upper or lower
      case can be used.

      Associativity of operators is left to right, and the precedence of
      operators is identical to 'C':

          precedence      operator



                                    - 1 -       Formatted:  January 15, 2025






 RELS(1)                                                             RELS(1)
                              February 22, 1998



          high            ! = not
          middle          & = and
          lowest          | = or

      The operator symbols can be escaped with the "\" character to include
      the symbol in a search pattern. The "escape space" character sequence
      represents one or more instances of space character(s) in search
      patterns, and each instance will match one or more consecutive
      whitespace characters, (as defined by isspace(3) in ctype.h and/or
      locale.h,) and allows phrases to be searched for. The "many to one"
      whitespace character translation occurs in both the keyword arguments
      and the text document(s). Multiple consecutive instances of the
      "escape space" character sequence in keyword search phrases should not
      be used, and single instances are appropriate only when necessary to
      specify a consecutive sequence of keywords-the logical and operator is
      the preferred searching construct when searching documents that
      contain set(s) of keywords.

      Note that the logical or operator, (|) is useful in conjunction with a
      thesaurus. For example, the thesaurus entry for the word "complexity"
      is:

          Complexity. -- N. complexity; complexness &c. adj.;
          complexus; complication, implication; intricacy,
          intrication; perplexity; network, labyrinth;
          wilderness, jungle; involution, raveling,
          entanglement; coil &c.  (convolution) 248; sleave,
          tangled skein, knot, Gordian knot, wheels within
          wheels; kink, knarl; webwork.

               Adj.  knarled. complex, complexed; intricate,
               complicated, perplexed, involved, raveled,
               entangled, knotted, tangled, inextricable;
               irreducible.

      implying that a reasonable context for a search for things that are
      complex would be:

          rels '(complex | complic | implicat | intric |
               perplex | labyrinth | involut | convolut |
               involv | tangl | inextric | irreduc)' ...

      which would probably return too many document names. The number of
      documents can be reduced with the logical and (&) and not (!) operator
      in an iterative fashion to reject documents of little interest.

 DOCUMENT FORMAT ISSUES
      Hyphenation issues are addressed by deleting hyphens and any following
      sequence of instances of whitespace characters, (as defined by
      isspace(3),) in both the keyword arguments and the text document(s).




                                    - 2 -       Formatted:  January 15, 2025






 RELS(1)                                                             RELS(1)
                              February 22, 1998



      Backspace character issues are addressed by overwriting the character
      before the backspace with the character after the backspace, which
      will instantiate the character of the last instance of of consecutive
      backspace/character combinations. This is specifically for catman
      pages which utilize underscore/backspace/character combinations for
      underlining, in addition to backspace/character combinations for bold
      (overstrike,) representation-note that for this process to be
      successful, a single underscore (used for underlining,) must preceed a
      single character in the sequence.

 PHONETIC TRANSLATION
      This program is a derivative works based on the rel(1) program,
      available from sunsite.unc.edu in /pub/Linux/utils/text/rel-
      1.3.tar.gz. The sources were modified to include a soundex search
      algorithm.

      The soundex algorithm is a mechanical phonetic translation system for
      the English language, and converts English words into a corresponding
      phonetic code for the word. The algorithm is as follows:

          for each character in a word:

              if the character is the first character of a word

                  1) do nothing

              else

                  2) replace consecutive sequences of the
                  labials, (ie., the characters, B, F, P, V,)
                  with the character '1'

                  3) replace consecutive sequences of the
                  gutterals and sibilants, (ie., the characters,
                  C, G, J, K, Q, S, X, Z,) with the character
                  '2'

                  4) replace consecutive sequences of the
                  dentals, (ie., the characters, D, T,) with the
                  character '3'

                  5) replace consecutive sequences of the
                  longliquids, (ie., the character, L,) with the
                  character '4'

                  6) replace consecutive sequences of the
                  nasals, (ie., the characters, M, N,) with the
                  character '5'

                  7) replace consecutive sequences of the
                  shortliquids, (ie., the character, R,) with



                                    - 3 -       Formatted:  January 15, 2025






 RELS(1)                                                             RELS(1)
                              February 22, 1998



                  the character '6'

                  8) and, omit all other characters, (ie., the
                  characters, A, E, H, I, O, U, W, Y,)

                  9) if the soundex translation of the word is
                  larger than 4 characters, truncate to 4
                  characters.

      For example, the soundex translation of the word "conover" is C516.
      Unfortunately, there are two related issues in using the soundex
      algorithm as a search mechanism; interior keyword search is
      impossible, and, there is no practical strategy to handle hyphenation.

      As a heuristic, simply eliminating 1), above, would permit interior
      keyword searches and hyphenation through concatenation of characters
      on each side of a '-' character, at the expense of erroneous matches.
      In practice, the expense is small-depending on the point of view-
      particularly if the requirement in 9), above, is removed, permitting
      soundex keyword translations of more syllables.

      Note that this heuristic returns soundex translated words that consist
      only of numbers. Since numerical data can be a valid search criteria,
      the ambiguity can be avoided by using letters from the alphabet for
      the numbers, making the algorithm as follows:

          1) replace consecutive sequences of the labials, (ie.,
          the characters, B, F, P, V,) with the character 'B'

          2) replace consecutive sequences of the gutterals and
          sibilants, (ie., the characters, C, G, J, K, Q, S, X,
          Z,) with the character
          'G'

          3) replace consecutive sequences of the dentals, (ie.,
          the characters, D, T,) with the character 'D'

          4) replace consecutive sequences of the longliquids,
          (ie., the character, L,) with the character 'L'

          5) replace consecutive sequences of the nasals, (ie.,
          the characters, M, N,) with the character 'N'

          6) replace consecutive sequences of the shortliquids,
          (ie., the character, R,) with the character 'S'

          7) and, omit all other characters, (ie., the
          characters, A, E, H, I, O, U, W, Y,)

      which turns out to be implementable as a direct, many-to-one, and on-
      to simple character mapping. It is, also, a very fast phonetic search



                                    - 4 -       Formatted:  January 15, 2025






 RELS(1)                                                             RELS(1)
                              February 22, 1998



      methodology-there is no speed penalty.

      Comparing the two methodologies, (standard soundex vs. modified
      soundex,) on a text version of the Webster's dictionary, (mine has
      234,932 words,) as to the number of different words recognized, with
      both unlimited soundex word length, and a word length of 4:

             standard soundex               modified soundex

          length = 4    unlimited        length = 4    unlimited

            4,335        61,408             932         31,983

      Although the modified soundex with unlimited length is inferior to the
      standard soundex with unlimited word length in capability of
      recognizing differences in words, it is superior to the standard
      soundex with a word length of 4, which is the way the algorithm is
      usually used. It would seem that the modified soundex algorithm is a
      reasonable, (depending on the point of view,) compromise for
      implementing a phonetic search algorithm.

      There are additional issues with the soundex algorithm for phonetic
      keyword searches:

          1) it only works for the English language

          2) a syntax error will be returned for keywords made
          up of ONLY the characters A, E, I, H, O, U, W, and Y,
          (there is nothing to search for-these characters are
          ignored by the soundex algorithm)

          3) Extreme care must be exercised when using the
          algorithm to reject documents with the logical not
          operator (!) since it will reject more documents than
          probably expected.

      meaning that the algorithm should be considered as an adjunct to,
      instead of a replacement for, a strict keyword search.

      Tests on large email archives, and the HTML pages from WWW servers
      (each about 15 Mbytes,) tend to indicate that, in practice, the
      algorithm returns not quite twice as many keyword matches as a strict
      keyword search. (The output of this program was compared to the output
      of the rel(1) program.)

 OPTIONS
      -v   Print the version and copyright banner of the program.

 WARNINGS
      In the interest of performance, Memory is allocated to hold the entire
      file to be searched.  Large files may create resource issues.



                                    - 5 -       Formatted:  January 15, 2025






 RELS(1)                                                             RELS(1)
                              February 22, 1998



      The "not" boolean operator, '!', can NOT be used to find the list of
      documents that do NOT contain a keyword or phrase, (unless used in
      conjunction with a preceeding boolean construct that will
      syntactically define an intermediate accept criteria for the
      documents.) The rationale is that the relevance of a set of documents
      that do NOT contain a phrase or keyword is ambiguous, and has no
      meaning-ie., how can documents be ordered that do not contain
      something?  Whether this is a bug, or not, depends on one's point of
      view.

      The phonetic translation only works for the English language.

      A syntax error will be returned for keywords made up of ONLY the
      characters A, E, I, H, O, U, W, and Y, (there is nothing to search
      for-these characters are ignored by the soundex algorithm).

      Extreme care must be exercised when using the algorithm to reject
      documents with the logical not operator (!) since it will reject more
      documents than probably expected.

 SEE ALSO
      egrep(1), agrep(1), rel(1)

 DIAGNOSTICS
      Error messages for illegal or incompatible search patterns, for non-
      regular, missing or inaccessible files and directories, or for
      (unlikely) memory allocation failure, and signal errors.

 AUTHORS
      ----------------------------------------------------------------------

      A license is hereby granted to reproduce this software source code and
      to create executable versions from this source code for personal,
      non-commercial use.  The copyright notice included with the software
      must be maintained in all copies produced.

      THIS PROGRAM IS PROVIDED "AS IS". THE AUTHOR PROVIDES NO WARRANTIES
      WHATSOEVER, EXPRESSED OR IMPLIED, INCLUDING WARRANTIES OF
      MERCHANTABILITY, TITLE, OR FITNESS FOR ANY PARTICULAR PURPOSE.  THE
      AUTHOR DOES NOT WARRANT THAT USE OF THIS PROGRAM DOES NOT INFRINGE THE
      INTELLECTUAL PROPERTY RIGHTS OF ANY THIRD PARTY IN ANY COUNTRY.

      Copyright (c) 1995, 1996, 1997, 1998 John Conover, All Rights Reserved.

      Comments and/or bug reports should be addressed to:

          john@johncon.com (John Conover)

      ----------------------------------------------------------------------





                                    - 6 -       Formatted:  January 15, 2025