source: cpp/frams/util/multimap.h @ 546

Last change on this file since 546 was 304, checked in by Maciej Komosinski, 10 years ago

Improved docs

  • Property svn:eol-style set to native
File size: 2.4 KB
RevLine 
[286]1// This file is a part of Framsticks SDK.  http://www.framsticks.com/
2// Copyright (C) 1999-2015  Maciej Komosinski and Szymon Ulatowski.
3// See LICENSE.txt for details.
[109]4
5#ifndef _MULTIMAP_H_
6#define _MULTIMAP_H_
7
8#include "multirange.h"
9
10class SingleMapping
11{
12  public:
13SingleMapping(int b,const MultiRange& t):begin(b),to(t) {}
14SingleMapping(int b):begin(b) {}
15SingleMapping(const SingleMapping& sm):begin(sm.begin),to(sm.to) {}
16int begin;
17MultiRange to;
18};
19
20/** MultiMap - used for conversion mapping.
[304]21    Read about how mappings work: http://www.framsticks.com/files/common/GeneticMappingsInArtificialGenomes.pdf
[109]22    see @ref convmap
[304]23*/
[109]24class MultiMap
25{
26/** list of (SingleMapping*) */
27SList data;
28
29SingleMapping* getData(int i) const {return (SingleMapping*)data(i);}
30void addData(int i,SingleMapping* mapping) {data.insert(i,(void*)mapping);}
31void removeData(int i) {data.remove(i);}
32int findData(int x) const;
33int getBegin(int i) const {return getData(i)->begin;}
34
35// addRangeXXX return the shift for range numbers > r
36int addRange(int &r,const MultiRange& mr);
37// value of 'r' is adjusted according to its range number change
38int addRangeBeginEnd(int &r,int begin,int end,const MultiRange& mr);
39
40  public:
41MultiMap() {}
42MultiMap(const MultiMap& mm) {operator=(mm);}
43~MultiMap();
44void operator=(const MultiMap& mm);
45
46void clear();
47int isEmpty() const {return data.size()==0;}
48int mappingCount() const {return data.size();}
49SingleMapping* getMapping(int i) const {return (SingleMapping*)getData(i);}
50int findMappingId(int x) const {return findData(x);}
51int rangeCount() const {return isEmpty()?0:data.size()-1;}
52IRange getRange(int i) const;
53
54int getBegin() const;
55int getEnd() const;
56
57void add(const IRange& from,const IRange& to) {add(from.begin, from.end, MultiRange(to));}
58void add(const IRange& from,const MultiRange& to) {add(from.begin, from.end, to);}
59void add(int from1,int from2,int to1,int to2) {add(from1,from2,MultiRange(to1,to2));}
60void add(int from1,int from2,const MultiRange& to);
61void add(const MultiRange& from,const MultiRange& to);
62void add(const MultiMap& mm);
63void addCombined(const MultiMap& m1,const MultiMap& m2);
64void addReversed(const MultiMap& mm);
65
66const MultiRange& map(int x) const;
67MultiRange map(int begin,int end) const;
68MultiRange map(const IRange& range) const {return map(range.begin, range.end);}
69MultiRange map(const MultiRange& ranges) const;
70
71void print() const;
72void print2() const;
73};
74
75#endif
Note: See TracBrowser for help on using the repository browser.