adamstark@93: //=======================================================================
adamstark@93: /** @file CircularBuffer.h
adamstark@111: * @brief A circular buffer
adamstark@93: * @author Adam Stark
adamstark@93: * @copyright Copyright (C) 2008-2014 Queen Mary University of London
adamstark@93: *
adamstark@93: * This program is free software: you can redistribute it and/or modify
adamstark@93: * it under the terms of the GNU General Public License as published by
adamstark@93: * the Free Software Foundation, either version 3 of the License, or
adamstark@93: * (at your option) any later version.
adamstark@93: *
adamstark@93: * This program is distributed in the hope that it will be useful,
adamstark@93: * but WITHOUT ANY WARRANTY; without even the implied warranty of
adamstark@93: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
adamstark@93: * GNU General Public License for more details.
adamstark@93: *
adamstark@93: * You should have received a copy of the GNU General Public License
adamstark@93: * along with this program. If not, see .
adamstark@93: */
adamstark@93: //=======================================================================
adamstark@89:
adamstark@89: #ifndef CircularBuffer_h
adamstark@89: #define CircularBuffer_h
adamstark@89:
adamstark@89: #include
adamstark@89:
adamstark@93: //=======================================================================
adamstark@93: /** A circular buffer that allows you to add new samples to the end
adamstark@93: * whilst removing them from the beginning. This is implemented in an
adamstark@107: * efficient way which doesn't involve any memory allocation as samples
adamstark@107: * are added to the end of the buffer
adamstark@93: */
adamstark@89: class CircularBuffer
adamstark@89: {
adamstark@89: public:
adamstark@93:
adamstark@93: /** Constructor */
adamstark@93: CircularBuffer()
adamstark@93: : writeIndex (0)
adamstark@89: {
adamstark@89:
adamstark@89: }
adamstark@89:
adamstark@93: /** Access the ith element in the buffer */
adamstark@93: double &operator[] (int i)
adamstark@89: {
adamstark@89: int index = (i + writeIndex) % buffer.size();
adamstark@89: return buffer[index];
adamstark@89: }
adamstark@93:
adamstark@93: /** Add a new sample to the end of the buffer */
adamstark@89: void addSampleToEnd (double v)
adamstark@89: {
adamstark@89: buffer[writeIndex] = v;
adamstark@89: writeIndex = (writeIndex + 1) % buffer.size();
adamstark@89: }
adamstark@89:
adamstark@93: /** Resize the buffer */
adamstark@93: void resize (int size)
adamstark@89: {
adamstark@92: buffer.resize (size);
adamstark@105: std::fill (buffer.begin(), buffer.end(), 0.0);
adamstark@89: writeIndex = 0;
adamstark@89: }
adamstark@89:
adamstark@107: /** Returns the size of the buffer */
adamstark@105: int size()
adamstark@105: {
adamstark@105: return static_cast (buffer.size());
adamstark@105: }
adamstark@105:
adamstark@89: private:
adamstark@89:
adamstark@89: std::vector buffer;
adamstark@89: int writeIndex;
adamstark@89: };
adamstark@89:
adamstark@89: #endif /* CircularBuffer_hpp */