diff options
Diffstat (limited to 'libstdc++-v3/testsuite/ext/pb_ds/regression')
11 files changed, 952 insertions, 0 deletions
diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/associative_containers.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/associative_containers.cc new file mode 100644 index 000000000..26dec124d --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/associative_containers.cc @@ -0,0 +1,165 @@ +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file assoc_link_regression_test_1.cpp + * A linkage regression test. + */ + + +#include <ext/pb_ds/assoc_container.hpp> +#include <iostream> +#include <cassert> + +using namespace std; +using namespace __gnu_pbds; + +/** + * The following function performs a sequence of operations on an + * associative container object mapping integers to characters. + */ +template<typename Cntnr> +void +some_op_sequence(Cntnr& r_c) +{ + assert(r_c.empty()); + assert(r_c.size() == 0); + + r_c.insert(make_pair(1, 'a')); + + r_c[2] = 'b'; + + assert(!r_c.empty()); + assert(r_c.size() == 2); + + cout << "Key 1 is mapped to " << r_c[1] << endl; + cout << "Key 2 is mapped to " << r_c[2] << endl; + + cout << endl << "All value types in the container:" << endl; + for (typename Cntnr::const_iterator it = r_c.begin(); it != r_c.end(); ++it) + cout << it->first << " -> " << it->second << endl; + + cout << endl; + + r_c.clear(); + + assert(r_c.empty()); + assert(r_c.size() == 0); +} + +void +assoc_link_regression_test_0() +{ + { + // Perform operations on a collision-chaining hash map. + cc_hash_table<int, char> c; + some_op_sequence(c); + } + + { + // Perform operations on a general-probing hash map. + gp_hash_table<int, char> c; + some_op_sequence(c); + } + + { + // Perform operations on a red-black tree map. + tree<int, char> c; + some_op_sequence(c); + } + + { + // Perform operations on a splay tree map. + tree<int, char, less<int>, splay_tree_tag> c; + some_op_sequence(c); + } + + { + // Perform operations on a splay tree map. + tree<int, char, less<int>, ov_tree_tag> c; + some_op_sequence(c); + } + + { + // Perform operations on a list-update map. + list_update<int, char> c; + some_op_sequence(c); + } +} + + +void +assoc_link_regression_test_1() +{ + { + // Perform operations on a collision-chaining hash map. + cc_hash_table<int, char> c; + some_op_sequence(c); + } + + { + // Perform operations on a general-probing hash map. + gp_hash_table<int, char> c; + some_op_sequence(c); + } + + { + // Perform operations on a red-black tree map. + tree<int, char> c; + some_op_sequence(c); + } + + { + // Perform operations on a splay tree map. + tree<int, char, less<int>, splay_tree_tag> c; + some_op_sequence(c); + } + + { + // Perform operations on a splay tree map. + tree<int, char, less<int>, ov_tree_tag> c; + some_op_sequence(c); + } + + { + // Perform operations on a list-update map. + list_update<int, char> c; + some_op_sequence(c); + } +} + +int +main() +{ + assoc_link_regression_test_0(); + assoc_link_regression_test_1(); + return 0; +} diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/hash_data_map_rand.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/hash_data_map_rand.cc new file mode 100644 index 000000000..5656a5b29 --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/hash_data_map_rand.cc @@ -0,0 +1,73 @@ +// { dg-require-time "" } +// This can take long on simulators, timing out the test. +// { dg-options "-DITERATIONS=5" { target simulator } } +// { dg-timeout-factor 2.0 } + +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file hash_data_map_rand_regression_test.cpp + * Contains a random-operation test for maps and sets. + */ + +#define PB_DS_REGRESSION + +#include <regression/rand/assoc/rand_regression_test.hpp> +#include <regression/common_type.hpp> + +#ifndef ITERATIONS +# ifdef _GLIBCXX_DEBUG +# define ITERATIONS 100 +# else +# define ITERATIONS 5000 +#endif +#endif + +#ifndef KEYS +# ifdef _GLIBCXX_DEBUG +# define KEYS 200 +# else +# define KEYS 10000 +# endif +#endif + +int +main(int argc, char* a_p_argv[]) +{ + using namespace __gnu_pbds::test; + typedef hash_map_tl_t map_tl_t; + + return rand_regression_test(ITERATIONS, KEYS, + "hash_data_map_rand_regression_test", + map_tl_t()); +} + diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/hash_no_data_map_rand.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/hash_no_data_map_rand.cc new file mode 100644 index 000000000..e0530f579 --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/hash_no_data_map_rand.cc @@ -0,0 +1,72 @@ +// { dg-require-time "" } +// This can take long on simulators, timing out the test. +// { dg-options "-DITERATIONS=5" { target simulator } } +// { dg-timeout-factor 2.0 } + +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009, 2011 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file hash_no_data_map_rand_regression_test.cpp + * Contains a random-operation test for maps and sets. + */ + +#define PB_DS_REGRESSION + +#include <regression/rand/assoc/rand_regression_test.hpp> +#include <regression/common_type.hpp> + +#ifndef ITERATIONS +# ifdef _GLIBCXX_DEBUG +# define ITERATIONS 100 +# else +# define ITERATIONS 5000 +#endif +#endif + +#ifndef KEYS +# ifdef _GLIBCXX_DEBUG +# define KEYS 200 +# else +# define KEYS 10000 +# endif +#endif + +int +main(int argc, char* a_p_argv[]) +{ + using namespace __gnu_pbds::test; + typedef hash_set_tl_t map_tl_t; + + return rand_regression_test(ITERATIONS, KEYS, + "hash_no_data_map_rand_regression_test", + map_tl_t()); +} diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/list_update_data_map_rand.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/list_update_data_map_rand.cc new file mode 100644 index 000000000..8bd77816c --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/list_update_data_map_rand.cc @@ -0,0 +1,54 @@ +// { dg-require-time "" } + +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file lu_data_map_rand_regression_test.cpp + * Contains a random-operation test for maps and sets. + */ + +#define PB_DS_REGRESSION + +#include <regression/rand/assoc/rand_regression_test.hpp> +#include <regression/common_type.hpp> + +int +main(int argc, char* a_p_argv[]) +{ + using namespace __gnu_pbds::test; + typedef lu_map_tl_t map_tl_t; + + return rand_regression_test(50, 10, + "lu_data_map_rand_regression_test", + map_tl_t()); +} + diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/list_update_no_data_map_rand.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/list_update_no_data_map_rand.cc new file mode 100644 index 000000000..72273a8bc --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/list_update_no_data_map_rand.cc @@ -0,0 +1,54 @@ +// { dg-require-time "" } + +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file lu_no_data_map_rand_regression_test.cpp + * Contains a random-operation test for maps and sets. + */ + +#define PB_DS_REGRESSION + +#include <regression/rand/assoc/rand_regression_test.hpp> +#include <regression/common_type.hpp> + +int +main(int argc, char* a_p_argv[]) +{ + using namespace __gnu_pbds::test; + typedef lu_set_tl_t map_tl_t; + + return rand_regression_test(50, 10, + "lu_no_data_map_rand_regression_test", + map_tl_t()); +} + diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/priority_queue_rand.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/priority_queue_rand.cc new file mode 100644 index 000000000..b21f486d6 --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/priority_queue_rand.cc @@ -0,0 +1,61 @@ +// { dg-require-time "" } +// This can take long on simulators, timing out the test. +// { dg-options "-DITERATIONS=5" { target simulator } } +// { dg-timeout-factor 2.0 } + +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file priority_queue_rand_regression_test.cpp + * Contains a random-operation test for priority queues. + */ + +#define PB_DS_REGRESSION + +#include <regression/rand/priority_queue/rand_regression_test.hpp> +#include <regression/common_type.hpp> + +#ifndef ITERATIONS +#define ITERATIONS 5000 +#endif +#ifndef KEYS +#define KEYS 10000 +#endif +int +main(int argc, char* a_p_argv[]) +{ + using namespace __gnu_pbds::test; + return rand_regression_test(ITERATIONS, KEYS, + "pq_no_data_map_rand_regression_test", + pq_tl_t()); +} + diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/priority_queues.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/priority_queues.cc new file mode 100644 index 000000000..713c887a1 --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/priority_queues.cc @@ -0,0 +1,184 @@ +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * This example shows how to use priority queues. It defines a + * function performing a sequence of operations on + * a generic container. It then calls this function with some containers. + */ + +#include <ext/pb_ds/priority_queue.hpp> +#include <iostream> +#include <cassert> + +using namespace std; +using namespace __gnu_pbds; +using namespace __gnu_pbds; + +template<typename Cntnr> +void +some_op_sequence(Cntnr& r_c) +{ + assert(r_c.empty()); + assert(r_c.size() == 0); + + for (size_t i = 0; i < 10; ++i) + r_c.push(i); + + cout << endl << "All values in the container:" << endl; + for (typename Cntnr::const_iterator it = r_c.begin(); it != r_c.end(); + ++it) + cout <<* it << endl; + + assert(!r_c.empty()); + assert(r_c.size() == 10); + + cout << "Popping all values: " << endl; + + while (!r_c.empty()) + { + cout << r_c.top() << endl; + + r_c.pop(); + } + + assert(r_c.empty()); + assert(r_c.size() == 0); + + cout << endl; +} + +void +priority_queue_link_regression_test_0() +{ + { + /* + * Perform operations on a pairing-heap queue. + */ + cout << "Pairing heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, pairing_heap_tag> c; + some_op_sequence(c); + } + + { + /* + * Perform operations on a binomial-heap queue. + */ + cout << "Binomial heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, binomial_heap_tag> c; + some_op_sequence(c); + } + + { + /* + * Perform operations on a binomial-heap queue. + */ + cout << "Redundant-counter binomial heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, rc_binomial_heap_tag> c; + some_op_sequence(c); + } + + { + /* + * Perform operations on a binomial-heap queue. + */ + cout << "Binary heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, binary_heap_tag> c; + some_op_sequence(c); + } + + { + /* + * Perform operations on a thin-heap queue. + */ + cout << "Thin heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, thin_heap_tag> c; + some_op_sequence(c); + } +} + + +void +priority_queue_link_regression_test_1() +{ + { + /* + * Perform operations on a pairing-heap queue. + */ + cout << "Pairing heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, pairing_heap_tag> c; + some_op_sequence(c); + } + + { + /* + * Perform operations on a binomial-heap queue. + */ + cout << "Binomial heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, binomial_heap_tag> c; + some_op_sequence(c); + } + + { + /* + * Perform operations on a binomial-heap queue. + */ + cout << "Redundant-counter binomial heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, rc_binomial_heap_tag> c; + some_op_sequence(c); + } + + { + /* + * Perform operations on a binomial-heap queue. + */ + cout << "Binary heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, binary_heap_tag> c; + some_op_sequence(c); + } + + { + /* + * Perform operations on a thin-heap queue. + */ + cout << "Thin heap" << endl; + __gnu_pbds::priority_queue<int, less<int>, thin_heap_tag> c; + some_op_sequence(c); + } +} + +int +main() +{ + priority_queue_link_regression_test_0(); + priority_queue_link_regression_test_1(); + return 0; +} diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/tree_data_map_rand.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/tree_data_map_rand.cc new file mode 100644 index 000000000..01751e39f --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/tree_data_map_rand.cc @@ -0,0 +1,72 @@ +// { dg-require-time "" } +// This can take long on simulators, timing out the test. +// { dg-options "-DITERATIONS=5" { target simulator } } +// { dg-timeout-factor 2.0 } + +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009, 2011 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file tree_data_map_rand_regression_test.cpp + * Contains a random-operation test for maps and sets. + */ + +#define PB_DS_REGRESSION + +#include <regression/rand/assoc/rand_regression_test.hpp> +#include <regression/common_type.hpp> + +#ifndef ITERATIONS +# ifdef _GLIBCXX_DEBUG +# define ITERATIONS 100 +# else +# define ITERATIONS 5000 +#endif +#endif + +#ifndef KEYS +# ifdef _GLIBCXX_DEBUG +# define KEYS 200 +# else +# define KEYS 10000 +# endif +#endif + +int +main(int argc, char* a_p_argv[]) +{ + using namespace __gnu_pbds::test; + typedef tree_map_tl_t map_tl_t; + + return rand_regression_test(ITERATIONS, KEYS, + "tree_data_map_rand_regression_test", + map_tl_t()); +} diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/tree_no_data_map_rand.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/tree_no_data_map_rand.cc new file mode 100644 index 000000000..c7dadb0d8 --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/tree_no_data_map_rand.cc @@ -0,0 +1,73 @@ +// { dg-require-time "" } +// This can take long on simulators, timing out the test. +// { dg-options "-DITERATIONS=5" { target simulator } } +// { dg-timeout-factor 2.0 } + +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009, 2011 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file tree_no_data_map_rand_regression_test.cpp + * Contains a random-operation test for maps and sets. + */ + +#define PB_DS_REGRESSION + +#include <regression/rand/assoc/rand_regression_test.hpp> +#include <regression/common_type.hpp> + + +#ifndef ITERATIONS +# ifdef _GLIBCXX_DEBUG +# define ITERATIONS 100 +# else +# define ITERATIONS 5000 +#endif +#endif + +#ifndef KEYS +# ifdef _GLIBCXX_DEBUG +# define KEYS 200 +# else +# define KEYS 10000 +# endif +#endif + +int +main(int argc, char* a_p_argv[]) +{ + using namespace __gnu_pbds::test; + typedef tree_set_tl_t map_tl_t; + + return rand_regression_test(ITERATIONS, KEYS, + "tree_no_data_map_rand_regression_test", + map_tl_t()); +} diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/trie_data_map_rand.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/trie_data_map_rand.cc new file mode 100644 index 000000000..8a3902812 --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/trie_data_map_rand.cc @@ -0,0 +1,72 @@ +// { dg-require-time "" } +// This can take long on simulators, timing out the test. +// { dg-options "-DITERATIONS=5" { target simulator } } +// { dg-timeout-factor 2.0 } + +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009, 2011 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file trie_data_map_rand_regression_test.cpp + * Contains a random-operation test for maps and sets. + */ + +#define PB_DS_REGRESSION + +#include <regression/rand/assoc/rand_regression_test.hpp> +#include <regression/common_type.hpp> + +#ifndef ITERATIONS +# ifdef _GLIBCXX_DEBUG +# define ITERATIONS 100 +# else +# define ITERATIONS 5000 +#endif +#endif + +#ifndef KEYS +# ifdef _GLIBCXX_DEBUG +# define KEYS 200 +# else +# define KEYS 10000 +# endif +#endif + +int +main(int argc, char* a_p_argv[]) +{ + using namespace __gnu_pbds::test; + typedef trie_map_tl_t map_tl_t; + + return rand_regression_test(ITERATIONS, KEYS, + "trie_data_map_rand_regression_test", + map_tl_t()); +} diff --git a/libstdc++-v3/testsuite/ext/pb_ds/regression/trie_no_data_map_rand.cc b/libstdc++-v3/testsuite/ext/pb_ds/regression/trie_no_data_map_rand.cc new file mode 100644 index 000000000..2414118da --- /dev/null +++ b/libstdc++-v3/testsuite/ext/pb_ds/regression/trie_no_data_map_rand.cc @@ -0,0 +1,72 @@ +// { dg-require-time "" } +// This can take long on simulators, timing out the test. +// { dg-options "-DITERATIONS=5" { target simulator } } +// { dg-timeout-factor 2.0 } + +// -*- C++ -*- + +// Copyright (C) 2005, 2006, 2009, 2010, 2011 Free Software Foundation, Inc. +// +// This file is part of the GNU ISO C++ Library. This library 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, or (at your option) any later +// version. + +// This library 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 this library; see the file COPYING3. If not see +// <http://www.gnu.org/licenses/>. + + +// Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL. + +// Permission to use, copy, modify, sell, and distribute this software +// is hereby granted without fee, provided that the above copyright +// notice appears in all copies, and that both that copyright notice +// and this permission notice appear in supporting documentation. None +// of the above authors, nor IBM Haifa Research Laboratories, make any +// representation about the suitability of this software for any +// purpose. It is provided "as is" without express or implied +// warranty. + +/** + * @file trie_no_data_map_rand_regression_test.cpp + * Contains a random-operation test for maps and sets. + */ + +#define PB_DS_REGRESSION + +#include <regression/rand/assoc/rand_regression_test.hpp> +#include <regression/common_type.hpp> + +#ifndef ITERATIONS +# ifdef _GLIBCXX_DEBUG +# define ITERATIONS 100 +# else +# define ITERATIONS 5000 +#endif +#endif + +#ifndef KEYS +# ifdef _GLIBCXX_DEBUG +# define KEYS 200 +# else +# define KEYS 10000 +# endif +#endif + +int +main(int argc, char* a_p_argv[]) +{ + using namespace __gnu_pbds::test; + typedef trie_set_tl_t map_tl_t; + + return rand_regression_test(ITERATIONS, KEYS, + "trie_no_data_map_rand_regression_test", + map_tl_t()); +} |