psycho-skin-mapgenerator.h
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039 #ifndef _PSYCHO_SKIN_MAPGENERATOE_H_
00040 #define _PSYCHO_SKIN_MAPGENERATOE_H_
00041 #include <vector>
00042 #include <string>
00043
00044
00045
00046 class Matrix
00047 {
00048 public:
00049 Matrix(int row , int col , int** mems);
00050 ~Matrix() ;
00051 int getNumOfRows();
00052 int getNumOfColumns();
00053 int get(int row , int col );
00054 void set(int row , int col , int val);
00055 void setNumOfColumns(int nc) ;
00056 void setNumOfRows(int nr);
00057 std::string toFormattedString() ;
00058 std::string toString();
00059 private:
00060 std::vector<int>* membs ;
00061 int* mems;
00062 int r ;
00063 int c ;
00064 std::string stringify(int i) ;
00065 } ;
00066
00067 Matrix* getARandomMap(int row , int col , int channel);
00068
00069 Matrix* getAnEmptyMap(int row , int col );
00070
00071 Matrix* getASeededMap(int row , int col , int numOfChannels , Matrix& p , int ch);
00072
00073 Matrix* getTheChannelMap(Matrix& map , int ch);
00074
00075 Matrix* getPattenByString(std::string patStr);
00076
00077 Matrix* getMapByString(std::string mapStr) ;
00078
00079 int getNumberOfMatches(Matrix& map , Matrix& pattern , int channel = 1);
00080
00081 int getNumberOfMatchesAgainstAllVariationsForAllChannels(Matrix& map , Matrix& pattern , int numOfChannels=6);
00082
00083 Matrix* getMatchMatrix(Matrix& map , Matrix& pattern , int channel);
00084
00085 Matrix* getTranspose(Matrix& m , bool replace = false ) ;
00086
00087 Matrix* getHorizontalReverse(Matrix& m , bool replace = false) ;
00088
00089 Matrix* getVerticalReverse(Matrix& m , bool replace = false) ;
00090
00091 std::vector<Matrix*> *getAllVariations(Matrix& p);
00092
00093 bool isInTheBag(Matrix& p , std::vector<Matrix*>&);
00094
00095 bool areTheyEqual(Matrix& a , Matrix& b);
00096
00097 std::vector<Matrix*> *getMapsWithExactPattenAndExactChannel(int rs , int cs , int numOfch , int ch , Matrix& p , int numOfMatches=1 , int n=1) ;
00098
00099 std::vector<Matrix*> *getPureMapsWithExactPatternAndExactChannel(int rs , int cs , int numOfch , int ch , Matrix& p , int numOfMatches=1 , int n=1) ;
00100
00101 std::vector<Matrix*> *getMapsWithExactPattenAndExactChannelWithExclusionList(int rs , int cs , int numOfch , int ch , Matrix& pattern ,std::vector<std::string>& exList, int numOfMatches , int n );
00102
00103 #endif
00104