Fork of Smoothie to port to mbed non-LPC targets.

Dependencies:   mbed

Fork of Smoothie by Stéphane Cachat

libs/Median.h

Committer:
Bigcheese
Date:
2014-03-02
Revision:
3:f151d08d335c
Parent:
2:1df0b61d3b5a

File content as of revision 3:f151d08d335c:

/*
      This file is part of Smoothie (http://smoothieware.org/). The motion control part is heavily based on Grbl (https://github.com/simen/grbl).
      Smoothie is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
      Smoothie is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
      You should have received a copy of the GNU General Public License along with Smoothie. If not, see <http://www.gnu.org/licenses/>.
*/

template <typename T>
void split(T data[], unsigned int n, T x, unsigned int& i, unsigned int& j)
{
  do {
    while (data[i] < x) i++;
    while (x < data[j]) j--;

    if (i <= j) {
      T ii = data[i];
      data[i] = data[j];
      data[j] = ii;
      i++; j--;
    }
  } while (i <= j);
}

// C.A.R. Hoare's Quick Median
template <typename T>
unsigned int quick_median(T data[], unsigned int n)
{
  unsigned int l = 0, r = n-1, k = n/2;
  while (l < r) {
    T x = data[k];
    unsigned int i = l, j = r;
    split(data, n, x, i, j);
    if (j < k) l = i;
    if (k < i) r = j;
  }
  return k;
}