SWI-Prolog supports compilation of individual or multiple Prolog 
source files into‘Quick Load Files'. A‘Quick Load File' (.qlf 
file) stores the contents of the file in a precompiled format.
These files load considerably faster than source files and are normally more compact. They are machine-independent and may thus be loaded on any implementation of SWI-Prolog. Note, however, that clauses are stored as virtual machine instructions. Changes to the compiler will generally make old compiled files unusable.
Quick Load Files are created using qcompile/1. 
They are loaded using
consult/1 
or one of the other file-loading predicates described in
section 4.3. If consult/1 
is given an explicit .pl file, it will load the Prolog 
source. When given a .qlf file, it will load the file. When 
no extension is specified, it will load the
.qlf file when present and the .pl file 
otherwise.
.qlf. 
The basename of the Quick Load File is the same as the input file.
If the file contains‘:- consult(+File)’,‘:- 
[+File]’or‘:- load_files(+File, 
[qcompile(part), ...])’statements, the referred files are 
compiled into the same .qlf file. Other directives will be 
stored in the
.qlf file and executed in the same fashion as when loading 
the
.pl file.
For term_expansion/2, the same rules as described in section 2.11 apply.
Conditional execution or optimisation may test the predicate compiling/0.
Source references (source_file/2) in the Quick Load File refer to the Prolog source file from which the compiled code originates.
user. When specified, files loaded 
indirectly from File that to not come from the Prolog library 
are included into the .qlf file. This may be used to 
generate a single file from an application. The result is comparable to 
a save state (see qsave_program/2) 
with the folowing differences:
.qlf files cannot include 
arbitrary resources.