IsBlockDesign( obj )
This boolean function  returns true if and only if obj, which can be
an object of arbitrary type, is a block design.
gap> IsBlockDesign(5); false gap> IsBlockDesign( BlockDesign(2,[[1],[1,2],[1,2]]) ); true
IsBinaryBlockDesign( D )
This boolean function  returns true if and only if the block design
D is binary, that is, if no block of D has a repeated element.
gap> IsBinaryBlockDesign( BlockDesign(2,[[1],[1,2],[1,2]]) ); true gap> IsBinaryBlockDesign( BlockDesign(2,[[1],[1,2],[1,2,2]]) ); false
IsSimpleBlockDesign( D )
This boolean function  returns true if and only if the block design
D is simple, that is, if no block of D is repeated.
gap> IsSimpleBlockDesign( BlockDesign(2,[[1],[1,2],[1,2]]) ); false gap> IsSimpleBlockDesign( BlockDesign(2,[[1],[1,2],[1,2,2]]) ); true
IsConnectedBlockDesign( D )
This boolean function  returns true if and only if the block design
D is connected, that is, if its incidence graph is a connected
graph.
gap> IsConnectedBlockDesign( BlockDesign(2,[[1],[2]]) ); false gap> IsConnectedBlockDesign( BlockDesign(2,[[1,2]]) ); true
BlockDesignPoints( D )
This function returns the set of points of the block design D, that is
[1..D.v]. The returned result is immutable.
gap> D:=BlockDesign(3,[[1,2],[1,3],[2,3],[2,3]]); rec( isBlockDesign := true, v := 3, blocks := [ [ 1, 2 ], [ 1, 3 ], [ 2, 3 ], [ 2, 3 ] ] ) gap> BlockDesignPoints(D); [ 1 .. 3 ]
NrBlockDesignPoints( D )
This function returns the number of points of the block design D.
gap> D:=BlockDesign(3,[[1,2],[1,3],[2,3],[2,3]]); rec( isBlockDesign := true, v := 3, blocks := [ [ 1, 2 ], [ 1, 3 ], [ 2, 3 ], [ 2, 3 ] ] ) gap> NrBlockDesignPoints(D); 3
BlockDesignBlocks( D )
This function returns the (sorted) list of blocks of the block design D. The returned result is immutable.
gap> D:=BlockDesign(3,[[1,2],[1,3],[2,3],[2,3]]); rec( isBlockDesign := true, v := 3, blocks := [ [ 1, 2 ], [ 1, 3 ], [ 2, 3 ], [ 2, 3 ] ] ) gap> BlockDesignBlocks(D); [ [ 1, 2 ], [ 1, 3 ], [ 2, 3 ], [ 2, 3 ] ]
NrBlockDesignBlocks( D )
This function returns the number of blocks of the block design D.
gap> D:=BlockDesign(3,[[1,2],[1,3],[2,3],[2,3]]); rec( isBlockDesign := true, v := 3, blocks := [ [ 1, 2 ], [ 1, 3 ], [ 2, 3 ], [ 2, 3 ] ] ) gap> NrBlockDesignBlocks(D); 4
BlockSizes( D )
This function returns the set of sizes (actually list-lengths) of the blocks of the block design D.
gap> BlockSizes( BlockDesign(3,[[1],[1,2,2],[1,2,3],[2],[3]]) ); [ 1, 3 ]
BlockNumbers( D )
Let D be a block design. Then this function returns a list of
the same length as BlockSizes(D), such that the i-th element 
of this returned list is the number of blocks of D of size
BlockSizes(D)[i].
gap> D:=BlockDesign(3,[[1],[1,2,2],[1,2,3],[2],[3]]); rec( isBlockDesign := true, v := 3, blocks := [ [ 1 ], [ 1, 2, 2 ], [ 1, 2, 3 ], [ 2 ], [ 3 ] ] ) gap> BlockSizes(D); [ 1, 3 ] gap> BlockNumbers(D); [ 3, 2 ]
ReplicationNumber( D )
If the block design D is equireplicate, then this function returns
its replication number; otherwise fail is returned.
A block design D is equireplicate with replication number r if, for every point x of D, r is equal to the sum over the blocks of the multiplicity of x in a block. For a binary block design this is the same as saying that each point x is contained in exactly r blocks.
gap> ReplicationNumber(BlockDesign(4,[[1],[1,2],[2,3,3],[4,4]])); 2 gap> ReplicationNumber(BlockDesign(4,[[1],[1,2],[2,3],[4,4]])); fail
PairwiseBalancedLambda( D )
A binary block design D is pairwise balanced if D has at least two points and every pair of distinct points is contained in exactly lambda blocks, for some positive constant lambda.
Given a binary block design D, this function returns fail if D is
not pairwise balanced, and otherwise the positive constant lambda such
that every pair of distinct points of D is in exactly lambda blocks.
gap> D:=BlockDesigns(rec(v:=10, blockSizes:=[3,4],       
>          tSubsetStructure:=rec(t:=2,lambdas:=[1])))[1];
rec( isBlockDesign := true, v := 10, 
  blocks := [ [ 1, 2, 3, 4 ], [ 1, 5, 6, 7 ], [ 1, 8, 9, 10 ], [ 2, 5, 10 ], 
      [ 2, 6, 8 ], [ 2, 7, 9 ], [ 3, 5, 9 ], [ 3, 6, 10 ], [ 3, 7, 8 ], 
      [ 4, 5, 8 ], [ 4, 6, 9 ], [ 4, 7, 10 ] ], 
  tSubsetStructure := rec( t := 2, lambdas := [ 1 ] ), isBinary := true, 
  isSimple := true, blockSizes := [ 3, 4 ], blockNumbers := [ 9, 3 ], 
  autGroup := Group([ (5,6,7)(8,9,10), (2,3)(5,7)(8,10), 
      (2,3,4)(5,7,6)(8,9,10), (2,3,4)(5,9,6,8,7,10), (2,6,9,3,7,10)(4,5,8) ]) 
 )
gap> PairwiseBalancedLambda(D);                          
1
TSubsetLambdasVector( D, t )
Let D be a block design, t a non-negative integer, and 
v=D.v. Then this function returns an integer vector L 
whose positions correspond to the t-subsets of {1,...,v}.
The i-th element of L is the sum over all blocks B of D 
of the number of times the i-th t-subset (in lexicographic order) 
is contained in B. (For example, if t=2 and B=[1,1,2,3,3,4], then
B contains [1,2] twice, [1,3] four times, [1,4] twice,
[2,3] twice, [2,4] once, and [3,4] twice.) In particular, 
if D is binary then L[i] is simply the number of blocks of D 
containing the i-th t-subset (in lexicographic order).
gap> D:=BlockDesign(3,[[1],[1,2,2],[1,2,3],[2],[3]]);; gap> TSubsetLambdasVector(D,0); [ 5 ] gap> TSubsetLambdasVector(D,1); [ 3, 4, 2 ] gap> TSubsetLambdasVector(D,2); [ 3, 1, 1 ] gap> TSubsetLambdasVector(D,3); [ 1 ]
AllTDesignLambdas( D )
If the block design D is not a t-design for some tge0 then this function returns an empty list. Otherwise D is a binary block design with constant block size k, say, and this function returns a list L of length T+1, where T is the maximum tlek such that D is a t-design, and, for i=1,...,T+1, L[i] is equal to the (constant) number of blocks of D containing an (i-1)-subset of the point-set of D. The returned result is immutable.
gap> AllTDesignLambdas(PGPointFlatBlockDesign(3,2,1)); [ 35, 7, 1 ]
AffineResolvableMu( D )
A block design is affine resolvable if the design is resolvable and any two blocks not in the same parallel class of a resolution meet in a constant number mu of points.
If the block design D is affine resolvable, then this function
returns its value of mu; otherwise fail is returned.
The value 0 is returned if, and only if, D consists of a single parallel class.
gap> P:=PGPointFlatBlockDesign(2,3,1);; # projective plane of order 3 gap> AffineResolvableMu(P); fail gap> A:=ResidualBlockDesign(P,P.blocks[1]);; # affine plane of order 3 gap> AffineResolvableMu(A); 1
[Up] [Previous] [Next] [Index]
design manual