X-Git-Url: https://ruin.nu/git/?a=blobdiff_plain;f=src%2Fgenealgorithms.cpp;h=e96c9be63e9d378187a0d58b9413905bf6517e20;hb=bd6d14a70222d80caf00cee73b3014d392dbc69f;hp=154df354bc346592f53a1373b49bbc1c72a0b79d;hpb=74e3465418ae60633025efb581e399308ffdf4b1;p=germs.git diff --git a/src/genealgorithms.cpp b/src/genealgorithms.cpp index 154df35..e96c9be 100644 --- a/src/genealgorithms.cpp +++ b/src/genealgorithms.cpp @@ -22,31 +22,16 @@ #include "geneorder.h" #include +#include #include +#include using namespace std; std::pair longestSequences(const GeneOrder& go){ + vector > v = robinsonSchensted(go); + return pair(v[0].size(),v.size()); } - -/* -robSche2 :: [Int] -> [[Int]] -> [[Int]] -robSche2 [] ys = ys -robSche2 (x:xs) ys = robSche2 xs $ robSche4 x ys - -robSche3 :: Int -> [Int] -> (Maybe Int,[Int]) -robSche3 x ys = let yless = [y | y <- ys, y < x] in - let ymore = [y | y <- ys, y > x] in - case ymore of - [] -> (Nothing, yless++[x]) - (y:ys) -> (Just y, yless++(x:ys)) - -robSche4 :: Int -> [[Int]] -> [[Int]] -robSche4 x [] = [[x]] -robSche4 x (y:ys) = case robSche3 x y of - (Nothing, y) -> y:ys - (Just x, y) -> y:robSche4 x ys -*/ std::vector > robinsonSchensted(const GeneOrder& go){ vector > v; for (GeneOrder::iterator i = go.begin(); i != go.end(); ++i){ @@ -70,3 +55,80 @@ std::vector > robinsonSchensted(const GeneOrder& go){ } return v; } + +struct FindP{ + size_t p; + FindP(size_t p) : p(p) {} + bool operator()(Interval i){ + return (i.first == p || i.second == p); + } +}; + + +int countCycles(const GeneOrder& go){ + int cycles = 0; + set marked; + vector intervals = findIntervals(go); + vector points = findIntervalsAtPoints(intervals); + for (size_t p = 1; p < go.size(); ++p){ + if (marked.find(p) != marked.end()) + continue; + Interval i = intervals[points[p].first]; + while (marked.find(p) == marked.end()){ + marked.insert(p); + if (i == intervals[points[p].first]) + i = intervals[points[p].second]; + else + i = intervals[points[p].first]; + + if (p == i.first) + p = i.second; + else + p = i.first; + } + ++cycles; + } + return cycles; +} + +std::vector findComponents(const GeneOrder& go){ + return vector(); +} + +/** + * + */ +std::vector findIntervals(const GeneOrder& go){ + vector intervals(go.size()-1,Interval(go.size(),go.size())); + size_t n = 0; + for (GeneOrder::iterator g = go.begin(); g != go.end(); ++g, ++n){ + size_t i = abs(*g); + if (i < go.size() - 1) + intervals[i].first = n + (*g >= 0 ? 1 : 0); + if (i > 0) + intervals[i-1].second = n + (*g < 0 ? 1 : 0); + } + return intervals; +} + +/** + * + */ +std::vector findIntervalsAtPoints(const vector& intervals){ + size_t max = intervals.size()+1; + vector points(max,Interval(max,max)); + size_t n = 0; + for (vector::const_iterator i = intervals.begin(); i != intervals.end(); ++i, ++n){ + if (points[i->first].first == max){ + points[i->first].first = n; + }else + points[i->first].second = n; + + if (points[i->second].first == max){ + points[i->second].first = n; + }else + points[i->second].second = n; + } + return points; + +}