updates to documentation

This commit is contained in:
Vítor Santos Costa 2014-09-12 18:50:04 -05:00
parent 57ecd61b95
commit 882eaca30c
10 changed files with 251 additions and 197 deletions

View File

@ -495,7 +495,8 @@
@file absmi.c
@page Efficiency Efficiency Considerations
@defgroup Efficiency Efficiency Considerations
@ingroup YAPProgramming
We next discuss several issues on trying to make Prolog programs run
fast in YAP. We assume two different programming styles:
@ -508,10 +509,6 @@ loop(Env) :-
do_something(Env,NewEnv),
loop(NewEnv).
~~~~~
*/

View File

@ -1,7 +1,10 @@
@section CHR CHR: Constraint Handling Rules
@defgroup CHR CHR: Constraint Handling Rules
@ingroup SWILibrary
@{
This chapter is written by Tom Schrijvers, K.U. Leuven for the hProlog
system. Adjusted by Jan Wielemaker to fit the SWI-Prolog documentation
infrastructure and remove hProlog specific references.
@ -97,8 +100,6 @@ the arrow (either `<=>` or `==>`)
@}
@defgroup Semantics Semantics
@ingroup CHR_Syntax_and_Semantics
@{
@ -136,7 +137,7 @@ or another variable involved in one or more constraints. In that case the
constraint is triggered, i.e. it becomes an active constraint and all
the rules are tried.
@}
@ -169,14 +170,12 @@ constraints are not called in the body.
@defgroup CHR_Rule_Names Rule Names
@ingroup CHR_Rule_Types
@{
Naming a rule is optional and has no semantical meaning. It only functions
as documentation for the programmer.
@}
@defgroup CHRPragmas Pragmas
@ingroup CHR
@ -192,7 +191,7 @@ passive constraint in that rule.
Additional pragmas may be released in the future.
@}
@defgroup CHR_Options Options
@ -311,9 +310,7 @@ never load different chr files with the same CHR module name.
@defgroup Constraint_declaration Constraint declaration
@defgroup Constraint_declaration Constraint Declarations
@ingroup CHR_in_YAP_Programs
@{
@ -338,7 +335,7 @@ The new style is as follows:
@defgroup Compilation Compilation
@ingroup CHR_in_YAP
@ingroup CHR_in_YAP_Programs
The
SWI-Prolog CHR compiler exploits term_expansion/2 rules to translate
@ -371,7 +368,7 @@ leak into modules where they might cause conflicts.
@defgroup CHR_Debugging CHR Debugging
@ingroup CHR_in_YAP
@ingroup CHR_in_YAP_Programs
@{
@ -382,10 +379,6 @@ controlled by the CHR option debug, whose default is derived
from the SWI-Prolog flag `generate_debug_info`. Therefore debug
info is provided unless the `-nodebug` is used.
@defgroup Ports Ports
@ingroup CHR_Debugging
@ -423,11 +416,6 @@ An active constraints commits to a rule with possibly
some passive constraints. The apply port is entered
just after committing to the rule.
@defgroup Tracing Tracing
@ingroup CHR_Debugging
@ -618,4 +606,12 @@ Make sure to disable debug (`-nodebug`) and enable optimization
@}
@}
@}
@}
@}
@}

View File

@ -786,7 +786,12 @@ WARN_LOGFILE =
# INPUT = /Users/vsc/git/yap-6.3/packages/cplint/mcintyre.pl
#INPUT = /Users/vsc/git/yap-6.3/packages/R/R.pl
INPUT = foreigns.yap docs/yap.md docs/chr.md docs/threads.md docs/syntax.md docs/clpqr.md \
INPUT = foreigns.yap \
docs/yap.md \
docs/chr.md \
docs/threads.md \
docs/syntax.md \
docs/clpqr.md \
pl \
C \
H \

View File

@ -1,7 +1,6 @@
@defgroup Syntax YAP Syntax
@ingroup YAPProgramming
@{
@page YAPSyntax Syntax
We will describe the syntax of YAP at two levels. We first will
describe the syntax for Prolog terms. In a second level we describe

View File

@ -1,7 +1,7 @@
@defgroup Threads Threads
@ingroup YAPExtensions
@{
YAP implements a SWI-Prolog compatible multithreading
library. Like in SWI-Prolog, Prolog threads have their own stacks and
@ -10,19 +10,11 @@ global non-backtrackable data. The package is based on the POSIX thread
standard (Butenhof:1997:PPT) used on most popular systems except
for MS-Windows.
@defgroup Creating_and_Destroying_Prolog_Threads Creating and Destroying Prolog Threads
@ingroup Threads
@pred thread_create(: _Goal_, - _Id_, + _Options_)
Create a new Prolog thread (and underlying C-thread) and start it
by executing _Goal_. If the thread is created successfully, the
thread-identifier of the created thread is unified to _Id_.
@ -62,10 +54,6 @@ This implies further instantiation of this term in either thread does
not have consequences for the other thread: Prolog threads do not share
data from their stacks.
@defgroup Monitoring_Threads Monitoring Threads
@ingroup Threads
@ -153,6 +141,7 @@ attributes, but the clause-list is different in each thread.
@defgroup Thread_Synchronisation Thread Synchronisation
@ingroup Threads
All
internal Prolog operations are thread-safe. This implies two Prolog
@ -187,3 +176,4 @@ change_address(Id, Address) :-
@}

View File

@ -1,32 +1,32 @@
This file documents the YAP Prolog System version 6.3.4, a high-performance Prolog compiler developed at LIACC, Universidade do Porto. YAP is based on David H. D. Warren's WAM (Warren Abstract Machine), with several optimizations for better performance. YAP follows the Edinburgh tradition, and is largely compatible with DEC-10 Prolog, Quintus Prolog, and especially with C-Prolog.
+ @subpage DownloadInstall
+ @ref DownloadInstall
+ @subpage Run describes how to invoke YAP
+ @ref Run describes how to invoke YAP
+ @subpage YAPLoading presents the main predicates and
+ @ref YAPLoading presents the main predicates and
directives available to load files and to control the Prolog
environment.
+ @ref YAPConsulting
+ @ref YAPModules introduces the YAP module system and meta-predicates.
+ @subpage YAPBuiltins describes predicates providing core YAP
+ @ref YAPBuiltins describes predicates providing core YAP
functionality:
+ @subpage YAPExtensions presents several extensions over standard
+ @ref YAPExtensions presents several extensions over standard
Prolog
+ @subpage YAPProgramming
+ @ref YAPProgramming
+ @subpage ChYInterface
+ @ref ChYInterface
+ @subpage YAPLibrary
+ @ref YAPLibrary
+ @subpage SWILibrary
+ @ref SWILibrary
+ @subpage Packages
+ @ref Packages
\author Vitor Santos Costa,
@ -139,7 +139,6 @@ laboratory at the University of Ferrara. Please see
<http://www.ing.unife.it/Docenti/FabrizioRiguzzi/>
+ The CUDA interface package developed by Carlos Martínez, Jorge
Buenabad, Inês Dutra and Vítor Santos Costa.
@ -185,7 +184,6 @@ for more information on SWI-Prolog and the SWI packages.
@page DownloadInstall Downloading, Compiling, and Installing YAP
The latest development version of Yap-6 is yap-6.3.4 and can be
obtained from the repositories
@ -619,7 +617,7 @@ do not consult initial files
do not print informational messages
+ --
separator for arguments to Prolog code. These arguments are visible
through the [unix/1](@ref unix) built-in predicate.
through the unix/1 built-in predicate.
Note that YAP will output an error message on the following conditions:
@ -627,8 +625,10 @@ Note that YAP will output an error message on the following conditions:
+
a file name was given but the file does not exist or is not a saved
YAP state;
+
the necessary amount of memory could not be allocated;
+
the allocated memory is not enough to restore the state.
@ -746,6 +746,7 @@ they must be sent directly to the argv built-in. Hence, running
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./dump_args test
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
will write `test` on the standard output.
@defgroup YAPLoading Loading and Organising YAP Programs
@ -768,7 +769,8 @@ Prolog programs.
In the description of the arguments of functors the following notation
will be used:
+ a preceding plus sign will denote an argument as an "input argument" - it cannot be a free variable at the time of the call;
+ a preceding plus sign will denote an argument as an "input
argument" - it cannot be a free variable at the time of the call;
+ a preceding minus sign will denote an "output argument";
+ an argument with no preceding symbol can be used in both ways.
@ -802,7 +804,6 @@ will be used:
@defgroup ChYInterface Foreign Language interface to YAP
YAP provides the user with three facilities for writing
predicates in a language other than Prolog. Under Unix systems,
most language implementations were linkable to `C`, and the first interface exported the YAP machinery to the C language. YAP also implements most of the SWI-Prolog foreign language interface.
@ -815,135 +816,128 @@ being designed to work with the swig (@url(www.swig.org}) interface compiler.
@defgroup YAPExtensions Extensions to core Prolog.
@page YAP Extensions
+ @ref Rational_Trees
+ @subpage Rational_Trees
+ @ref CohYroutining
+ @subpage CohYroutining
+ @ref Attributed_Variables
+ @subpage Attributed_Variables
+ @ref DepthLimited
+ @subpage DepthLimited
+ @ref Tabling
+ @subpage Tabling
+ @ref Threads
+ @subpage Threads
+ @ref Profiling
+ @subpage Profiling
+ @ref YAPArrays
+ @subpage YAPArrays
+ @subpage Parallelism
+ @ref Parallelism
@defgroup YAPLibrary The YAP Library
@page LIbrary The YAP Library
+ @subpage maplist introduces macros to apply an operation over
+ @ref maplist introduces macros to apply an operation over
all elements of a list
+ @subpage Apply Apply Macros
+ @ref Apply Apply Macros
+ @subpage Association_Lists Association Lists
+ @ref Association_Lists Association Lists
+ @subpage AVL_Trees AVL Trees
+ @ref AVL_Trees AVL Trees
+ @subpage Exo_Intervals Exo Intervals
+ @ref Exo_Intervals Exo Intervals
+ @subpage Heaps Heaps
+ @ref Heaps Heaps
+ @subpage Lists List Manipulation
+ @ref Lists List Manipulation
+ @subpage LineUtilities Line Manipulation Utilities
+ @ref LineUtilities Line Manipulation Utilities
+ @subpage matrix Matrix Library
+ @ref matrix Matrix Library
+ @subpage NonhYBacktrackable_Data_Structures Non-Backtrackable Data Structures
+ @ref NonhYBacktrackable_Data_Structures Non-Backtrackable Data Structures
+ @subpage Ordered_Sets Ordered Sets
+ @ref Ordered_Sets Ordered Sets
+ @subpage Pseudo_Random Pseudo Random Number Integer Generator
+ @ref Pseudo_Random Pseudo Random Number Integer Generator
+ @subpage Queues Queues
+ @ref Queues Queues
+ @subpage Random Random Number Generator
+ @ref Random Random Number Generator
+ @subpage RedhYBlack_Trees Red-Black Trees
+ @ref RedhYBlack_Trees Red-Black Trees
+ @subpage RegExp Regular Expressions
+ @ref RegExp Regular Expressions
+ @subpage Splay_Trees Splay Trees
+ @ref Splay_Trees Splay Trees
+ @subpage System Calling The Operating System from YAP
+ @ref System Calling The Operating System from YAP
+ @subpage Terms Utilities On Terms
+ @ref Terms Utilities On Terms
+ @subpage Tries Trie DataStructure
+ @ref Tries Trie DataStructure
+ @subpage Cleanup Call Cleanup
+ @ref Cleanup Call Cleanup
+ @subpage Timeout Calls With Timeout
+ @ref Timeout Calls With Timeout
+ @subpage Trees Updatable Binary Trees
+ @ref Trees Updatable Binary Trees
+ @subpage UGraphs Unweighted Graphs
+ @ref UGraphs Unweighted Graphs
+ @subpage DGraphs Directed Graphs
+ @ref DGraphs Directed Graphs
+ @subpage UnDGraphs Undirected Graphs
+ @ref UnDGraphs Undirected Graphs
+ @subpage DBUsage Memory Usage in Prolog Data-Base
+ @ref DBUsage Memory Usage in Prolog Data-Base
+ @subpage Lambda Lambda Expressions
+ @ref Lambda Lambda Expressions
+ @subpage Block_Diagram Block Diagram
+ @ref Block_Diagram Block Diagram
+ @subpage Invoking_Predicates_on_all_Members_of_a_List Invoking Predicates on all Members of a List
+ @ref Invoking_Predicates_on_all_Members_of_a_List Invoking Predicates on all Members of a List
@defgroup YAPProgramming Programming in YAP
@page Programming Programming in YAP
+ @subpage Syntax
+ @ref Syntax
+ @subpage Indexing
+ @subpage Deb_Interaction
+ @ref Indexing
+ @ref Deb_Interaction
@defgroup SWILibrary SWI-Prolog Libraries and Packages
@page SWI The SWI-Prolog Library and Packages
+ @ref Read_Utilities Read Utilities
+ @subpage Read_Utilities Read Utilities
+ @ref shlib SWI-Prolog's shlib library
+ @subpage shlib SWI-Prolog's shlib library
+ @ref Lambda Lambda Expressions
+ @subpage Lambda Lambda Expressions
+ @ref archive
+ archive
+ @ref CHR
+ @subpage CHR
+ @ref CLPQR
+ @subpage CLPQR
+ zlib
+ @ref zlib
@defgroup YAPPackages The YAP packages
@page Packages The YAP Packages
+ @subpage REAL
+ @subpage BDDs
+ @subpage Gecode
+ @subpage MYDDAS
+ @ref REAL
+ @ref BDDs
+ @ref Gecode
+ @ref MYDDAS
@page Compatibility Compatibility with Other Prolog systems

View File

@ -103,7 +103,7 @@ fetch_key(Keys, Index, Size, Key, CmpF, ActualIndex) :-
fetch_key(Keys, I1, Size, Key, CmpF, ActualIndex)
).
/** b_hash_size_lookup( +_Key_, +_Hash_, +NewVal )
/** b_hash_update( +_Key_, +_Hash_, +NewVal )
Update to the value associated with the ground term _Key_ in table _Hash_ to _NewVal_.
*/
@ -114,11 +114,11 @@ b_hash_update(Hash, Key, NewVal):-
array_element(Vals, ActualIndex, Mutable),
update_mutable(NewVal, Mutable).
/** b_hash_size_lookup( +_Key_, -_OldVal_, +_Hash_, +NewVal )
/** b_hash_update( +_Key_, -_OldVal_, +_Hash_, +NewVal )
Update to the value associated with the ground term _Key_ in table _Hash_ to _NewVal_, and unify _OldVal_ with the current value.
*/
b_hash_update(Hash, Key, OldVal, NewVal):-§
b_hash_update(Hash, Key, OldVal, NewVal):-
Hash = hash(Keys, Vals, Size, _, F, CmpF),
hash_f(Key,Size,Index,F),
fetch_key(Keys, Index, Size, Key, CmpF, ActualIndex),

View File

@ -1039,6 +1039,10 @@ c_links :-
open('foreigns.yap', write, S),
clinks(S).
clinks(S) :-
exported( ( _-M:F/A :- _-M1:F1/A ) ),
format( S, ':- export( ~a:~a/~d , ~a:~a/~d ).~n', [M,F,A , M1,F1,A] ),
fail.
clinks(S) :-
node( M, P, File-Line, c(F)),
format( S, ':- foreign_predicate( ~q , ~q , ~q , ~d ).~n', [M:P, F, File, Line] ),
@ -1212,7 +1216,7 @@ preprocess_file(F,F).
%%%%%%%
%% declare a concept exportable
%% declare a concept export1able
public( F, M, op(X,Y,Z) ) :-
retract( private( F, M:op(X,Y,Z) ) ),
fail.

View File

@ -6,10 +6,15 @@ This library provides an interface to the BDD package CUDD. It requires
CUDD compiled as a dynamic library. In Linux this is available out of
box in Fedora, but can easily be ported to other Linux
distributions. CUDD is available in the ports OSX package, and in
cygwin. To use it, call `:-use_module(library(bdd))`.
cygwin. To use it, call
~~~~~
:-use_module(library(bdd))`.
~~~~~
The following predicates construct a BDD:
\toc
*/
@ -42,27 +47,56 @@ tell_warning :-
:- catch(load_foreign_files([cudd], [], init_cudd),_,fail) -> true ; tell_warning.
/**
@pred bdd_new(? _Exp_, - _BddHandle_)
% create a new BDD from a tree.
/** @defgroup BDDs Binary Decision Diagrams and Friends
@ingroup YAPPackages
@{
create a new BDD from the logical expression _Exp_. The expression
may include:
This library provides an interface to the BDD package CUDD. It requires
CUDD compiled as a dynamic library. In Linux this is available out of
box in Fedora, but can easily be ported to other Linux
distributions. CUDD is available in the ports OSX package, and in
cygwin. To use it, call `:-use_module(library(bdd))`.
+ Logical Variables:
The following predicates construct a BDD:
a leaf-node can be a logical variable.
+ `0` and `1`
a leaf-node can also be bound to the two boolean constants.
+ `or( _X_, _Y_)`, `_X_ \/ _Y_`, `_X_ + _Y_`
disjunction
+ `and( _X_, _Y_)`, `_X_ /\ _Y_`, `_X_ * _Y_`
conjunction
+ `nand( _X_, _Y_)`
negated conjunction@
+ `nor( _X_, _Y_)`
negated disjunction
+ `xor( _X_, _Y_)`
exclusive or
+ `not( _X_)`, or `-_X_`
negation.
*/
bdd_new(T, Bdd) :-
term_variables(T, Vars),
bdd_new(T, Vars, Bdd).
/**
@pred bdd_new(? _Exp_, +_Vars_, - _BddHandle_)
Same as bdd_new/2, but receives a term of the form
`vs(V1,....,Vn)`. This allows incremental construction of BDDs.
*/
bdd_new(T, Vars, cudd(M,X,VS,TrueVars)) :-
term_variables(Vars, TrueVars),
VS =.. [vs|TrueVars],
@ -73,8 +107,6 @@ bdd_new(T, Vars, cudd(M,X,VS,TrueVars)) :-
Convert a _List_ of logical expressions of the form above, that
includes the set of free variables _Vars_, into a BDD accessible
through _BddHandle_.
*/
% create a new BDD from a list.
bdd_from_list(List, Vars, cudd(M,X,VS,TrueVars)) :-
@ -174,8 +206,6 @@ subtraction
+ or( _X_, _Y_), _X_ \/ _Y_
logical or
*/
mtbdd_new(T, Mtbdd) :-
term_variables(T, Vars),

View File

@ -1,4 +1,40 @@
/**
@defgroup CUDD CUDD Interface
@ingroup BDDs
@brief Interface to the CUDD Library
CUDD represents a BDD as a tree of DdNode structures. Each tree has a manager DdManager and a list of booleaan variables, also represented as DdNode structures. Mapping from an Prolog tree to a ground BDD involves the following steps:
1. Collect all logical variables in the Prolog term, and map each
variable $V$ to a boolean variable $i$ in the BDD. This is easily done
by having the variable as the argument argument $i$ of a Prolog
term. The implementation uses vars_of_term/2 and =../2.
2. Allocate an array of boolean variables.
3. Perform a posfix visit of the Prolog term, so that a new DdNode is
always obtained by composing its children nodes.
YAP supports a few tricks:
+ A term of the form `cudd(_Address_)` refers to a compiled BDD. Thus,
we can pass a BDD to another BDD, ie:
~~~~~.pl
bdd(BDD) :-
Vs = vs(X,Y,Z),
bdd_new(X+(Y*Z),Vs,BDD0),
bdd_new(xor(BDD0,-(nand(X,BDD0) + nor(Y,BDD0)) ), Vs, BDD).
~~~~~
This is useful to construct complex BDDs quickly, but does not mean
CUDD will generate better/faster code.
2.
*/
#include <stdio.h>
#include "config.h"
@ -857,3 +893,6 @@ init_cudd(void)
YAP_UserCPredicate("cudd_print", p_cudd_print, 3);
}
/**
*@}
*/