1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
// Copyright (C) 1995 The New York Group Theory Cooperative
// See magnus/doc/COPYRIGHT for the full notice.
// Contents: Definition of the RandomMSCGroup class
//
// Principal Author: Dmitry Bormotov
//
// Status: in progress
//
// Usage:
//
// Special Notes:
//
// Revision History:
//
#ifndef _RANDOM_MSC_GROUP_H_
#define _RANDOM_MSC_GROUP_H_
#include "MSCGroup.h"
#include "RandomNumbers.h"
#include "NormalRandomWord.h"
//----------------------- RandomMSCGroup ---------------------------//
class RandomMSCGroup {
public:
///////////////////////////////////////////////////////
// //
// Constructors: //
// //
///////////////////////////////////////////////////////
RandomMSCGroup (
int numOfGenerators, int generatorsSeed,
int meanLengthOfRelators, int lengthOfRelatorsStddev, int lengthOfRelatorsSeed,
int meanNumberOfRelators, int numberOfRelatorsStddev, int numberOfRelatorsSeed
) :
numOfGens ( numOfGenerators ), gensSeed ( generatorsSeed ),
meanLenOfRels ( meanLengthOfRelators ), lenOfRelsStddev ( lengthOfRelatorsStddev ),
lenOfRelsSeed ( lengthOfRelatorsSeed ), meanNumOfRels ( meanNumberOfRelators ),
numOfRelsStddev ( numberOfRelatorsStddev ), numOfRelsSeed ( numberOfRelatorsSeed )
{ }
///////////////////////////////////////////////////////
// //
// Accessors: //
// //
///////////////////////////////////////////////////////
FPGroup getRandomMSCGroup();
// This is non const functions.
private:
///////////////////////////////////////////////////////
// //
// Data members: //
// //
///////////////////////////////////////////////////////
int numOfGens;
int gensSeed;
int meanLenOfRels;
int lenOfRelsStddev;
int lenOfRelsSeed;
int meanNumOfRels;
int numOfRelsStddev;
NormalRandom numOfRelsSeed;
};
#endif
|