Quellcodebibliothek Statistik Leitseite products/sources/formale Sprachen/GAP/pkg/mapclass/lib/   (Algebra von RWTH Aachen Version 4.15.1©)  Datei vom 17.8.2022 mit Größe 7 kB image not shown  

Quelle  orbit.gi   Sprache: unbekannt

 
# This module is part of a GAP package MAPCLASS. 
# It contains a function computing the mapping
# class orbit of a tuple and the action of 
# the mapping class group on the orbit
#
# ASSUMPTIONS: (1) The principal relation on this tuple must be 1.
#              (2) The length of the tuple is >1.
#
# A.James,  K. Magaard, S. Shpectorov 2011



#
# MappingClassOrbitCore
# Main routine computing the orbit. Is wrapped by all other functions
#cv
InstallGlobalFunction(MappingClassOrbitCore, function(tuple,
  PrincipalFiniteGroup, OurG, PrincipalTuple, AbsGens,  OurN, OurFreeGroup,
  OurAction, OurAlpha, OurBeta, OurGamma,HashLength, MinimizationTree,
  MinimumSet)

  local k, i, T, Orb, r, ActionOnOrbit, a, h, TupleTable, IsSilent, ExTotal,
  CTotal, NOrbits, precentage, percentage, n, QuickMinimize, QuickMinimizeData,
  ccdata, mindata, fprecord, FingerPrinting;
  # DisplayOptionsStack();

  ## Data to store current access
  if not ValueOption("CurrentTotal") = fail then
    CTotal:= ValueOption("CurrentTotal");
  else
    CTotal:= false;
  fi;
  if not ValueOption("ExTotal") = fail then
    ExTotal:= ValueOption("ExTotal");
  else
    ExTotal:= 0;
  fi;
  if not ValueOption("NOrbits") = fail then
    NOrbits:= ValueOption("NOrbits");
  else
    NOrbits:= 0;
  fi;

  ## Method Selection Options
  if not ValueOption("FingerPrinting") = fail then
    FingerPrinting:=true;
  else
    FingerPrinting:=false;
    fprecord:=false;
  fi;
  
  if not ValueOption("QuickMinimize") = fail then
    QuickMinimize:=true;
    QuickMinimizeData:= ValueOption("QuickMinimizeData");
  else
    QuickMinimize:= false;
  fi;

  # Initialize orbit record
  Orb:=rec();
  Orb.AbsGens:=AbsGens;
  Orb.OurFreeGroup:=OurFreeGroup;
  Orb.HashLength:=HashLength;
  Orb.MinimizationTree:=MinimizationTree;
  Orb.MinimumSet:=MinimumSet;
  Orb.OurR:=Length(PrincipalTuple);
  Orb.OurG:=OurG;
  Orb.NumberOfGenerators:=2*OurG + Orb.OurR;
  Orb.OurAction:=OurAction;
  Orb.OurAction:=OurAction;
  Orb.OurAlpha:=OurAlpha;
  Orb.OurBeta:=OurBeta;
  Orb.OurN:=OurN;
  Orb.PrincipalFiniteGroup:=PrincipalFiniteGroup;

  # tables...
  r:=InitializeTable(Orb.HashLength,2*Orb.OurG+Orb.OurR,Orb.OurN);
  Orb.Hash:=r.hash;
  Orb.PrimeCode:=r.primecode;
  TupleTable:=r.table;


  ## Minimization Data
  if QuickMinimize then
    Print("Preparing Minimization...\n");
    ccdata:=QuickMinimizeData.ccdata;
    mindata:=QuickMinimizeData.mindata;
  fi;

  ## FingerPrinting Data
  ## A record with keys
  #  -NumTestWords,
  #  -fingerfun
  #  -hashfn
  if FingerPrinting then
    ## Print("Preparing Finger Printing...\n");
    fprecord:= InitializeFingerprintTable(Orb);
  fi;


  # first tuple...
  # we want to split this so that we can use a choice of techniques.
  if IsAbelian(PrincipalFiniteGroup) then
    T:=ShallowCopy(tuple);
  else

    if QuickMinimize then

      T:=QuickMinimizeTuple(tuple, MinimizationTree, MinimumSet,
          Orb.NumberOfGenerators, mindata, ccdata);
    elif FingerPrinting then
      T:=tuple;
    else
      T:=MinimizeTuple(tuple, Orb.MinimizationTree, Orb.MinimumSet,
          Orb.NumberOfGenerators);
    fi;
  fi;

  if FingerPrinting = true then
    a:=LookUpTupleFP(T, fprecord, Orb, TupleTable);
  else
    a:=LookUpTuple(T, Orb.PrimeCode, Orb.HashLength, TupleTable, Orb.Hash,
        Orb.OurN);
  fi;

  if a=fail then

    if FingerPrinting = true then
      AddTupleFP(T, fprecord, Orb, TupleTable);
    else
      a:=AddTuple(T,Orb.PrimeCode,Orb.HashLength,TupleTable, Orb.Hash,
          Orb.OurN);
    fi;
  fi;


# action on the orbit...
  ActionOnOrbit:=List(Orb.OurAction,x->[]);
  
  # 
  # Generating the orbit
  #
  
  k:=0;
  n:= Size(PrincipalFiniteGroup) / Size(Center(PrincipalFiniteGroup));
  while k<Length(TupleTable) do
    k:=k+1;
    for i in [1..Length(Orb.OurAction)] do
      T:=List(Orb.OurAction[i],x->MappedWord(x,Orb.AbsGens,TupleTable[k].tuple));
      if not IsAbelian(Orb.PrincipalFiniteGroup) then
      
        ## Method Selection
        if FingerPrinting = true then
          # do nothing to T 
          T:=T;
        elif QuickMinimize = true then
          T:=QuickMinimizeTuple(T, MinimizationTree, MinimumSet,
              Orb.NumberOfGenerators, mindata, ccdata);
        else
          T:=MinimizeTuple(T, Orb.MinimizationTree, Orb.MinimumSet,
              Orb.NumberOfGenerators);
        fi;
        
      fi;
#     Check whether the tuple is in the table or not and if not then add it
#     Also have option to not use a generating lookup table
      if FingerPrinting = true then
        ActionOnOrbit[i][k]:=LookUpTupleFP(T, fprecord, Orb, TupleTable);
      else
        ActionOnOrbit[i][k]:=LookUpTuple(T,Orb.PrimeCode, Orb.HashLength,
          TupleTable, Orb.Hash, Orb.OurN);
      fi;

      if (ActionOnOrbit[i][k]= fail) then
        if FingerPrinting = true then
          ActionOnOrbit[i][k]:=AddTupleFP(T, fprecord, Orb, TupleTable);
        else
          ActionOnOrbit[i][k]:=AddTuple(T,Orb.PrimeCode, Orb.HashLength,
            TupleTable, Orb.Hash, Orb.OurN);
        fi;
      fi;
    od;
    percentage:= Int(100*((CTotal + n*Length(TupleTable))/ExTotal));
    MaybePrint([],
    ["\rOrbit ", NOrbits, "; Total % of tuples found: ", percentage, "%\c\r" ],
    ["\r",k," points checked, ",Length(TupleTable),
    " points total (difference ",Length(TupleTable)-k,")\c"]);
    
  od;
  MaybePrint([],
    [],
    ["\r",List([1..70],x->' '),"\c\r"]);
  Orb.TupleTable:=TupleTable;
  Orb.ActionOnOrbit:=ActionOnOrbit;
  Orb.FingerPrinting:=FingerPrinting;
  Orb.fprecord:=fprecord;
  return Orb;
end);

#
# MappingClassOrbit
# Given the usual parameters + an addition tuple number computes the tule table
# for said tuple. A wrapper for MappingClassOrbit
#
InstallGlobalFunction(MappingClassOrbit,function(group, genus, principaltuple, partition, tuple)

  local k, i, T, orb, r, ActionOnOrbit, a, h, TupleTable, OurN, OurR, AbsGens,
   OurFreeGroup, MinimumSet, MinimizationTree, record, OurAlpha, x0,
  OurBeta, OurGamma, OurAction, NumberOfGenerators, Orb, IsSilent, FixElem, rep; 
  # Get OptionStack values
  if not ValueOption("Silent") = fail then 
    IsSilent:=ValueOption("Silent"); 
  else
    IsSilent:=false;
  fi;
  if not ValueOption("FixElem") = fail then 
    FixElem:=true;
    x0:=ValueOption("FixElem");
  else
    FixElem:=false;
  fi;
  if not IsBool(IsSilent) then
    IsSilent:=false;
  fi;

  Orb:=rec();
  OurN:=NrMovedPoints(group);
  OurR:=Length(principaltuple);
  if Length(principaltuple)<>Length(tuple) then
    Print("Tuple Lengths do not match\n");
    return fail;
  fi;
  
  # construct abstract generators
  NumberOfGenerators:=2*genus + OurR;
  OurFreeGroup:=FreeGroup(NumberOfGenerators);
  AbsGens:=GeneratorsOfGroup(OurFreeGroup);
  OurAlpha:=AbsGens{[1..genus]};
  OurBeta:=AbsGens{[genus+1..2*genus]};
  OurGamma:=AbsGens{[2*genus+1..2*genus+OurR]};


# Mapping Class Action
# If FixElem is true then we restrict the orbit to those elements fixing the
# first element
  Print("FixElem:=", FixElem, "\n");
  if FixElem = true then
    OurAction:= MappingClassGroupGeneratorsL(genus, OurR, AbsGens, OurAlpha,
                OurBeta, OurGamma, partition);
    Print(OurAction);
    rep:=RepresentativeAction(group, tuple[1], x0);
    Apply(tuple, z -> z^rep);
  else
    OurAction:= MappingClassGroupGenerators(genus, OurR, AbsGens, OurAlpha,
              OurBeta, OurGamma, partition);
  fi;

# Prepare Minimization
  record:=PrepareMinTree(tuple, group, OurR, genus);
  MinimizationTree:=record.MinimizationTree;
  MinimumSet:=record.MinimumSet;

# Compute orbit
  Orb:=MappingClassOrbitCore(tuple, "single", group, genus, principaltuple,
        AbsGens, OurN, OurFreeGroup, OurAction, OurAlpha, OurBeta, OurGamma,
        5000, MinimizationTree, MinimumSet);
  return Orb;
end);
# End

[ Dauer der Verarbeitung: 0.38 Sekunden  (vorverarbeitet)  ]