 
    
      When reading a file with loadWeights or loadExamples or writing a
      file with saveWeights,
      saveExamples, or openNetOutputFile,
      file names with the extension .gz, .bz, .bz2, or .Z will
      automatically be decompressed or compressed as appropriate.
      When loading a file, if a file with the exact name does not
      exist but a file of the same name plus .gz, .bz, .bz2, or .Z
      does exists, the compressed file will be decompressed.
      Therefore, the user need not know in advance if the file is
      compressed.  If a file name does not begin with "-"
      or "|" it will be treated as an actual file rather
      than a pipeline or Tcl channel.
    
      If the file name is simply a dash ("-"), standard input or
      standard output will be used, as appropriate.  If the name begins with a
      dash, the remainder of the name will be treated as the name of an
      existing Tcl channel.  A Tcl channel is created with the open
      command and closed with close.
      The channel can be a file or a command pipeline and may be opened for
      reading, writing, or both.  The channel will still be open when the Lens
      command using it completes.  The following example shows how to use a
      filter, chooseExample, that chooses the next training
      example given the network's output on the previous example:
    
    lens> set channel [open |chooseExample RDWR]
    lens> openNetOutputFile -$channel
    lens> loadExamples -$channel -s theSet -m PIPE
    lens> useTrainingSet theSet
    lens> train
    lens> deleteExampleSet theSet
    lens> close $channel
    
      If the file name begins with a pipe ("|"), a process will
      be started and the data read from or written to the pipeline.  This is
      an alternate way to interact with a pipeline that avoids having to open
      and close a Tcl channel.  This differs in that the pipeline will be
      closed when the command completes (except when using the
      openNetOutputFile
      command).  In addition, there is no way
      to create a two-way pipe as in the previous example without making it a
      channel.
    
The description of the xor.in network gives an illustration of how an example-generating program can be used in this way.
      The following will let you preview the output of saveExamples by piping
      it through more:
    
    lens> saveExamples "my set" |more
    
      To write to a pipeline whose description consists of more than one word,
      you will need to enclose the command and the initial | in
      quotes:
    
    lens> saveExamples "my set" "| grep name | sort -r > names"
    You could also read from a pipeline, which would be convenient when generating example sets on the fly. Note that the usage of the pipe symbol is a bit unconventional here, since we are reading from the pipeline rather than writing to it. The first example reads from a file, discarding the example tags. The second reads from a process that is presumably generating a finite number of examples. If you have trouble reading from pipes, read this note.
    lens> loadExamples "| grep -v tag mySet.ex" -s "my set"
    lens> loadExamples "| genex 1000" -s "my set"
    Finally, you can specify example sets by hand by doing this:
    
    lens> loadExamples "|cat" -s toySet
    ...and then typing in your example set and pressing Ctrl-d when you are
    done.  This is useful if you are just experimenting and want a very small
    example file or perhaps if you don't feel like ftping a file but you can
    use your mouse to copy and paste a small example file.
    Automatic decompression, reading from a pipe, and reading from stdin, will not work for script files run with the source command or for postscript files generated when a display is printed.