updates to documentation
This commit is contained in:
parent
57ecd61b95
commit
882eaca30c
@ -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).
|
||||
~~~~~
|
||||
|
||||
|
||||
|
||||
|
||||
*/
|
||||
|
||||
|
||||
|
42
docs/chr.md
42
docs/chr.md
@ -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
|
||||
@}
|
||||
|
||||
|
||||
@}
|
||||
|
||||
@}
|
||||
|
||||
@}
|
||||
|
||||
@}
|
||||
|
||||
@}
|
||||
|
@ -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 \
|
||||
|
@ -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
|
||||
|
@ -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) :-
|
||||
|
||||
|
||||
|
||||
@}
|
||||
|
144
docs/yap.md
144
docs/yap.md
@ -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
|
||||
|
||||
|
@ -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),
|
||||
|
@ -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.
|
||||
|
@ -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),
|
||||
|
@ -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);
|
||||
}
|
||||
|
||||
/**
|
||||
*@}
|
||||
*/
|
||||
|
Reference in New Issue
Block a user