Quellcodebibliothek Statistik Leitseite products/sources/formale Sprachen/GAP/pkg/genss/doc/   (Algebra von RWTH Aachen Version 4.15.1©)  Datei vom 29.6.2024 mit Größe 8 kB image not shown  

Quelle  backtrack.xml   Sprache: XML

 
<!-- 

      backtrack.xml            genss package documentation
                                                                Max Neunhoeffer
                                                                   Felix Noeske

         Copyright (C) 2006-2009 by the authors.

This chapter explains how to use backtrack search methods.

-->


<Chapter Label="Backtrack">
<Heading>Backtrack search methods</Heading>

This chapter describes the methods for backtrack search in the
<Package>genss</Package> package. Note that the code in this area
is not yet very stable and is almost certainly going to change
in subsequent versions of this package. This might also concern
the interfaces and calling conventions.

<Section>
    <Heading>Setwise stabilisers</Heading>

<ManSection>
<Oper Name="SetwiseStabilizer" Arg="G, op, M"/>
<Returns>a record</Returns>
<Description>
    This operation computes the setwise stabiliser of the set <A>M</A>.
    So <A>G</A> must be a group acting on some set <M>\Omega</M>, 
    this action is
    given by the action function <A>op</A>. The set <A>M</A> must consist
    of elements <M>\Omega</M>. The result is a record with the
    components <C>setstab</C> containing the setwise stabiliser and
    <C>S</C> containing a stabiliser chain for it.
    <P/>
    This operation uses backtrack search in a specially crafted
    stabiliser chain for <A>G</A> doing not much intelligent pruning
    of the search tree, so expect possible long delays!
</Description>
</ManSection>

<ManSection>
<Oper Name="SetwiseStabilizerPartitionBacktrack" Arg="G, op, M"/>
<Returns>a record</Returns>
<Description>
    This operation computes the setwise stabiliser of the set <A>M</A>.
    So <A>G</A> must be a group acting on some set <M>\Omega</M>, 
    this action is
    given by the action function <A>op</A>. The set <A>M</A> must consist
    of elements <M>\Omega</M>. The result is a record with the
    components <C>setstab</C> containing the setwise stabiliser and
    <C>S</C> containing a stabiliser chain for it.
    <P/>
    This operation uses backtrack search in a specially crafted
    stabiliser chain for <A>G</A>. It does some ideas coming from
    partition backtrack but does not (yet) implement a full featured
   partition backtrack, so expect possible longish delays!
</Description>
</ManSection>

</Section>

<Section>
    <Heading>Generic backtrack search</Heading>

<ManSection>
<Oper Name="BacktrackSearchStabilizerChainElement" Arg="S, P, g, pruner"/>
<Returns><K>fail</K> or a group element</Returns>
<Description>
    Let <M>G</M> be the group described by the stabiliser chain <A>S</A>.
    The group element <A>g</A> must be some element in an overgroup 
    <M>\hat G</M>of
    <M>G</M> such that the function <A>P</A> described below is defined
    on the whole of <M>\hat G</M>
    <P/>
    This operation implements a generic backtrack search in the coset
    <M>G<A>g</A></M> looking for an element <M>x\ in G</M>
    such that <A>P</A><M>(x<A>g</A>)</M>
    is <K>true</K> where <A>P</A> is a function on <M>\hat G</M>taking
    values <K>true</K> and <K>false</K>.
    The operation returns the group
    element <M>x</M> if one is found or <K>fail</K> if none was found.
    <P/>
    The search tree is given by the stabiliser chain, each node corresponds
    to a right coset of one of the stabilisers in the chain. The leaves
    correspond to right cosets of the identity group, i.e. to group
    elements in <M>G<A>g</A></M>
    <P/>
    To make this backtrack search efficient some pruning of the search
    tree has to be done. To this end there is the fourth argument 
    <A>pruner</A> which can either be <K>false</K> (in which case no
    pruning at all happens) or a &GAP; function taking 5 arguments and
    returning either <K>true</K> or <K>false</K>. The function
    <A>pruner</A> is called for every node in the search tree before
    the backtrack search descents into the subtrees. If the <A>pruner</A> 
    function returns <K>false</K>, the complete subtree starting at
    the current node is pruned and no further search is performed
    there. If the result is <K>true</K> (or <A>pruner</A> was equal to
    <K>false</K> altogether) then the subtree starting at the current
    node is searched recursively. Obviously, the <A>pruner</A>
    function needs to know the current position in the search tree,
    which it is told by its arguments.
    <P/>
    Each node in the search tree corresponds to a coset of some
    stabiliser of the stabiliser chain in its previous one. To set up
    some notation, let 
    <Math> G = S_0 > S_1 > S_2 > \cdots > S_m > S_{{m+1}} = \{1\}
    </Math> be the stabiliser chain and let 
    <Math> O_1, O_2, \ldots, O_m </Math> be the basic orbits. Then for the 
    node corresponding to the coset <M>S_i t<A>g</A></M> 
    for <M>i \ge 1</M> and
    some transversal element <M>t</M> contained in <M>S_{{i-1}}</M>
    the arguments with which the <A>pruner</A> function is called
    are the following: The first argument is the stabiliser chain
    object corresponding to <M>S_{{i-1}}</M>. The second argument is
    the index of the element in <M>O_i</M> corresponding to the
    transversal element <M>t</M>. The third argument is the group
    element <M>t<A>g</A></M> and the fourth argument is
    equal to the actual transversal element <M>t</M>. The fifth
    argument is a word in the generators used to enumerate <M>O_i</M>
    expressing <M>t</M>, the word comes as a list of integers which
    are the generator numbers.
</Description>
</ManSection>

<ManSection>
<Oper Name="BacktrackSearchStabilizerChainSubgroup" Arg="S, P, pruner"/>
<Returns><K>fail</K> or a stabiliser chain</Returns>
<Description>
    Let <M>G</M> be the group described by the stabiliser chain <A>S</A>.
    This operation implements a generic backtrack search in the
    stabiliser chain <A>S</A> looking for the subgroup <M>H</M> of
    the group <M>G</M> described by <A>S</A> of all
    elements <M>x</M> for which <A>P</A><M>(x)</M>
    is <K>true</K>, where <A>P</A> is a function on <M>G</M> taking
    values <K>true</K> or <K>false</K>. Note that of course <A>P</A> must
    be such that <M>H</M> is actually a subgroup! 
    The operation returns a stabiliser chain describing the group <M>H</M>.
    <P/>
    The search tree is given by the stabiliser chain, each node corresponds
    to a right coset of one of the stabilisers in the chain. The leaves
    correspond to right cosets of the identity group, i.e. to group
    elements in <M>G</M>
    <P/>
    To make this backtrack search efficient some pruning of the search
    tree has to be done. To this end there is the fourth argument 
    <A>pruner</A> which can either be <K>false</K> (in which case no
    pruning at all happens) or a &GAP; function taking 5 arguments and
    returning either <K>true</K> or <K>false</K>. The function
    <A>pruner</A> is called for every node in the search tree before
    the backtrack search descents into the subtrees. If the <A>pruner</A> 
    function returns <K>false</K>, the complete subtree starting at
    the current node is pruned and no further search is performed
    there. If the result is <K>true</K> (or <A>pruner</A> was equal to
    <K>false</K> altogether) then the subtree starting at the current
    node is searched recursively. Obviously, the <A>pruner</A>
    function needs to know the current position in the search tree,
    which it is told by its arguments.
    <P/>
    Each node in the search tree corresponds to a coset of some
    stabiliser of the stabiliser chain in its previous one. To set up
    some notation, let 
    <Math> G = S_0 > S_1 > S_2 > \cdots > S_m > S_{{m+1}} = \{1\}
    </Math> be the stabiliser chain and let 
    <Math> O_1, O_2, \ldots, O_m </Math> be the basic orbits. Then for the 
    node corresponding to the coset <M>S_i t<A>g</A></M> 
    for <M>i \ge 1</M> and
    some transversal element <M>t</M> contained in <M>S_{{i-1}}</M>
    the arguments with which the <A>pruner</A> function is called
    are the following: The first argument is the stabiliser chain
    object corresponding to <M>S_{{i-1}}</M>. The second argument is
    the index of the element in <M>O_i</M> corresponding to the
    transversal element <M>t</M>. The third and fourth arguments are the
    transversal element <M>t</M>. The fifth
    argument is a word in the generators used to enumerate <M>O_i</M>
    expressing <M>t</M>, the word comes as a list of integers which
    are the generator numbers.
</Description>
</ManSection>

</Section>

<!-- ############################################################ -->

</Chapter>

Messung V0.5
C=97 H=100 G=98

¤ Dauer der Verarbeitung: 0.20 Sekunden  (vorverarbeitet)  ¤

*© Formatika GbR, Deutschland






Wurzel

Suchen

Beweissystem der NASA

Beweissystem Isabelle

NIST Cobol Testsuite

Cephes Mathematical Library

Wiener Entwicklungsmethode

Haftungshinweis

Die Informationen auf dieser Webseite wurden nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit, noch Qualität der bereit gestellten Informationen zugesichert.

Bemerkung:

Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.