dlib C++ Library - sliding_buffer.cpp

// Copyright (C) 2004 Davis E. King (davis@dlib.net)
// License: Boost Software License See LICENSE.txt for the full license.
#include <sstream>
#include <string>
#include <ctime>
#include <cstdlib>
#include <dlib/sliding_buffer.h>
#include "tester.h"
namespace 
{
 using namespace test;
 using namespace std;
 using namespace dlib;
 logger dlog("test.sliding_buffer");
 template <
 typename buf
 >
 void sliding_buffer_kernel_test (
 )
 /*!
 requires
 - buf is an implementation of sliding_buffer/sliding_buffer_kernel_abstract.h 
 - buf is instantiated with T=unsigned char
 ensures
 - runs tests on buf for compliance with the specs 
 !*/
 { 
 print_spinner();
 buf test;
 DLIB_TEST(test.size() == 0);
 test.set_size(3);
 buf test2;
 DLIB_TEST(test.size() == 8);
 for (int g = 0; g < 2; ++g)
 {
 test.clear();
 DLIB_TEST(test.size() == 0);
 test.set_size(2);
 DLIB_TEST(test.size() == 4);
 test[0] = 'a';
 test[1] = 's';
 test[2] = 'd';
 test[3] = 'f';
 unsigned long id = test.get_element_id(2);
 DLIB_TEST(test[test.get_element_index(id)] == 'd');
 DLIB_TEST(test[0] == 'a');
 DLIB_TEST(test[1] == 's');
 DLIB_TEST(test[2] == 'd');
 DLIB_TEST(test[3] == 'f');
 DLIB_TEST(test2.size() == 0);
 swap(test,test2);
 DLIB_TEST(test2.size() == 4);
 DLIB_TEST(test2[0] == 'a');
 DLIB_TEST(test2[1] == 's');
 DLIB_TEST(test2[2] == 'd');
 DLIB_TEST(test2[3] == 'f');
 swap(test,test2);
 test.rotate_left(4);
 DLIB_TEST(test[test.get_element_index(id)] == 'd');
 DLIB_TEST(test[0] == 'a');
 DLIB_TEST(test[1] == 's');
 DLIB_TEST(test[2] == 'd');
 DLIB_TEST(test[3] == 'f');
 test.rotate_right(1);
 DLIB_TEST(test[test.get_element_index(id)] == 'd');
 DLIB_TEST(test[0] == 's');
 DLIB_TEST(test[1] == 'd');
 DLIB_TEST(test[2] == 'f');
 DLIB_TEST(test[3] == 'a'); 
 test.rotate_left(1);
 DLIB_TEST(test[test.get_element_index(id)] == 'd');
 DLIB_TEST(test[0] == 'a');
 DLIB_TEST(test[1] == 's');
 DLIB_TEST(test[2] == 'd');
 DLIB_TEST(test[3] == 'f');
 test.rotate_left(16);
 DLIB_TEST(test[test.get_element_index(id)] == 'd');
 DLIB_TEST(test[0] == 'a');
 DLIB_TEST(test[1] == 's');
 DLIB_TEST(test[2] == 'd');
 DLIB_TEST(test[3] == 'f');
 test.rotate_left(2);
 DLIB_TEST(test[test.get_element_index(id)] == 'd');
 DLIB_TEST(test[0] == 'd');
 DLIB_TEST(test[1] == 'f');
 DLIB_TEST(test[2] == 'a');
 DLIB_TEST(test[3] == 's');
 test.rotate_left(1);
 DLIB_TEST(test[test.get_element_index(id)] == 'd');
 DLIB_TEST(test[0] == 's');
 DLIB_TEST(test[1] == 'd');
 DLIB_TEST(test[2] == 'f');
 DLIB_TEST(test[3] == 'a');
 test.rotate_left(1);
 DLIB_TEST(test[test.get_element_index(id)] == 'd');
 DLIB_TEST(test[0] == 'a');
 DLIB_TEST(test[1] == 's');
 DLIB_TEST(test[2] == 'd');
 DLIB_TEST(test[3] == 'f');
 DLIB_TEST(test.size() == 4);
 test[0] = 'x';
 DLIB_TEST(test[0] == 'x');
 DLIB_TEST(test[1] == 's');
 DLIB_TEST(test[2] == 'd');
 DLIB_TEST(test[3] == 'f');
 test.rotate_left(1);
 DLIB_TEST_MSG(test[0] == 'f',test[0]);
 DLIB_TEST(test[1] == 'x');
 DLIB_TEST(test[2] == 's');
 DLIB_TEST(test[3] == 'd');
 test[0] = 'x';
 DLIB_TEST(test[0] == 'x');
 DLIB_TEST(test[1] == 'x');
 DLIB_TEST(test[2] == 's');
 DLIB_TEST(test[3] == 'd');
 test.rotate_left(1);
 DLIB_TEST(test[0] == 'd');
 DLIB_TEST(test[1] == 'x');
 DLIB_TEST(test[2] == 'x');
 DLIB_TEST(test[3] == 's');
 DLIB_TEST(test.at_start() == true);
 DLIB_TEST(test.current_element_valid() == false);
 DLIB_TEST(test.move_next() == true);
 DLIB_TEST(test.at_start() == false);
 DLIB_TEST(test.current_element_valid() == true);
 test.clear();
 test2.clear();
 DLIB_TEST(test.size() == 0);
 DLIB_TEST(test.at_start() == true);
 DLIB_TEST(test.current_element_valid() == false);
 DLIB_TEST(test.move_next() == false);
 DLIB_TEST(test.at_start() == false);
 DLIB_TEST(test.current_element_valid() == false);
 swap(test,test2);
 DLIB_TEST(test2.at_start() == false);
 DLIB_TEST(test2.current_element_valid() == false);
 DLIB_TEST(test2.move_next() == false);
 DLIB_TEST(test2.at_start() == false);
 DLIB_TEST(test2.current_element_valid() == false);
 DLIB_TEST(test.at_start() == true);
 DLIB_TEST(test.current_element_valid() == false);
 DLIB_TEST(test.move_next() == false);
 DLIB_TEST(test.at_start() == false);
 test.set_size(3);
 DLIB_TEST(test.size() == 8);
 DLIB_TEST(test.at_start() == true);
 DLIB_TEST(test.current_element_valid() == false);
 DLIB_TEST(test.move_next() == true);
 DLIB_TEST(test.at_start() == false);
 DLIB_TEST(test.current_element_valid() == true);
 test.reset();
 DLIB_TEST(test.size() == 8);
 DLIB_TEST(test.at_start() == true);
 DLIB_TEST(test.current_element_valid() == false);
 DLIB_TEST(test.move_next() == true);
 DLIB_TEST(test.at_start() == false);
 DLIB_TEST(test.current_element_valid() == true);
 test.rotate_right(1);
 DLIB_TEST(test.size() == 8);
 DLIB_TEST(test.at_start() == true);
 DLIB_TEST(test.current_element_valid() == false);
 DLIB_TEST(test.move_next() == true);
 DLIB_TEST(test.at_start() == false);
 DLIB_TEST(test.current_element_valid() == true);
 test.rotate_left(1);
 DLIB_TEST(test.size() == 8);
 DLIB_TEST(test.at_start() == true);
 DLIB_TEST(test.current_element_valid() == false);
 DLIB_TEST(test.move_next() == true);
 DLIB_TEST(test.at_start() == false);
 DLIB_TEST(test.current_element_valid() == true);
 test.reset();
 for (unsigned long i = 0; i < test.size(); ++i)
 {
 test[i] = static_cast<unsigned char>(i);
 }
 unsigned long count = 0;
 while (test.move_next())
 {
 DLIB_TEST(test.element() == count);
 ++count;
 }
 DLIB_TEST(count == test.size());
 test2.clear();
 ostringstream sout;
 istringstream sin;
 serialize(test,sout);
 sin.str(sout.str());
 deserialize(test2,sin);
 char ch;
 sin >> ch;
 DLIB_TEST( !sin);
 DLIB_TEST(test2.size() == test.size());
 for (unsigned long i = 0; i < test.size(); ++i)
 {
 DLIB_TEST_MSG(test[i] == test2[i],
 "\ni: " << i <<
 "\ntest[i]: " << test[i] <<
 "\ntest2[i]: " << test2[i]);
 }
 count = 0;
 while (test.move_next() && test2.move_next())
 {
 DLIB_TEST(test.element() == count);
 DLIB_TEST(test2.element() == count);
 ++count;
 }
 DLIB_TEST(test2.size() == count);
 DLIB_TEST(test.size() == count);
 test2.clear();
 } // for (int g = 0; g < 2; ++g)
 }
 void test_circular_buffer()
 {
 circular_buffer<int> buf;
 DLIB_TEST(buf.size() == 0);
 buf.assign(4, 0);
 DLIB_TEST(buf.size() == 4);
 DLIB_TEST(buf[0] == 0);
 DLIB_TEST(buf[1] == 0);
 DLIB_TEST(buf[2] == 0);
 DLIB_TEST(buf[3] == 0);
 buf.push_back(1);
 DLIB_TEST(buf[0] == 0);
 DLIB_TEST(buf[1] == 0);
 DLIB_TEST(buf[2] == 0);
 DLIB_TEST(buf[3] == 1);
 buf.push_back(2);
 DLIB_TEST(buf[0] == 0);
 DLIB_TEST(buf[1] == 0);
 DLIB_TEST(buf[2] == 1);
 DLIB_TEST(buf[3] == 2);
 buf.push_front(3);
 DLIB_TEST(buf[0] == 3);
 DLIB_TEST(buf[1] == 0);
 DLIB_TEST(buf[2] == 0);
 DLIB_TEST(buf[3] == 1);
 buf.push_front(4);
 DLIB_TEST(buf.front() == 4);
 DLIB_TEST(buf[0] == 4);
 DLIB_TEST(buf[1] == 3);
 DLIB_TEST(buf[2] == 0);
 DLIB_TEST(buf[3] == 0);
 buf.assign(4, 5);
 DLIB_TEST(buf[0] == 5);
 DLIB_TEST(buf[1] == 5);
 DLIB_TEST(buf[2] == 5);
 DLIB_TEST(buf[3] == 5);
 buf.push_back(3);
 DLIB_TEST(buf[0] == 5);
 DLIB_TEST(buf[1] == 5);
 DLIB_TEST(buf[2] == 5);
 DLIB_TEST(buf[3] == 3);
 buf.push_back(2);
 DLIB_TEST(buf[0] == 5);
 DLIB_TEST(buf[1] == 5);
 DLIB_TEST(buf[2] == 3);
 DLIB_TEST(buf[3] == 2);
 buf.push_back(1);
 DLIB_TEST(buf[0] == 5);
 DLIB_TEST(buf[1] == 3);
 DLIB_TEST(buf[2] == 2);
 DLIB_TEST(buf[3] == 1);
 buf.push_back(0);
 DLIB_TEST(buf[0] == 3);
 DLIB_TEST(buf[1] == 2);
 DLIB_TEST(buf[2] == 1);
 DLIB_TEST(buf[3] == 0);
 buf.push_back(-1);
 DLIB_TEST(buf.back() == -1);
 DLIB_TEST(buf[0] == 2);
 DLIB_TEST(buf[1] == 1);
 DLIB_TEST(buf[2] == 0);
 DLIB_TEST(buf[3] == -1);
 buf.resize(1);
 buf[0] = 9;
 DLIB_TEST(buf.size() == 1);
 DLIB_TEST(buf[0] == 9);
 buf.push_back(1);
 DLIB_TEST(buf[0] == 1);
 buf.push_back(4);
 DLIB_TEST(buf[0] == 4);
 buf.push_front(3);
 DLIB_TEST(buf[0] == 3);
 buf.clear();
 DLIB_TEST(buf.size() == 0);
 buf.assign(3, 0);
 circular_buffer<int> buf2, buf3;
 buf.push_back(1);
 buf.push_back(2);
 ostringstream sout;
 serialize(buf, sout);
 istringstream sin(sout.str());
 deserialize(buf2, sin);
 DLIB_TEST(buf.size() == buf2.size());
 for (unsigned long i = 0; i < buf.size(); ++i)
 DLIB_TEST(buf[i] == buf2[i]);
 buf.swap(buf3);
 DLIB_TEST(buf.size() == 0);
 DLIB_TEST(buf3.size() == buf2.size());
 for (unsigned long i = 0; i < buf3.size(); ++i)
 DLIB_TEST(buf3[i] == buf2[i]);
 }
 class sliding_buffer_tester : public tester
 {
 public:
 sliding_buffer_tester (
 ) :
 tester ("test_sliding_buffer",
 "Runs tests on the sliding_buffer component.")
 {}
 void perform_test (
 )
 {
 dlog << LINFO << "testing kernel_1a";
 sliding_buffer_kernel_test<sliding_buffer<unsigned char>::kernel_1a> ();
 dlog << LINFO << "testing kernel_1a_c";
 sliding_buffer_kernel_test<sliding_buffer<unsigned char>::kernel_1a_c>();
 test_circular_buffer();
 }
 } a;
}

AltStyle によって変換されたページ (->オリジナル) /