summaryrefslogtreecommitdiff
path: root/include/phat/representations/Unordered_map_container_traits.h
diff options
context:
space:
mode:
authorGard Spreemann <gspr@nonempty.org>2020-08-27 12:35:45 +0200
committerGard Spreemann <gspr@nonempty.org>2020-08-27 12:35:45 +0200
commit0356915f2d3e4f41b1993fc4688f07431506f610 (patch)
tree6eecbae2c86e57948d94f76460929c1793c3813e /include/phat/representations/Unordered_map_container_traits.h
parenta378599c297e61be6543079945819e8da9d55b38 (diff)
parent746517263955660b5a0a0f4defc18f2d2d84f502 (diff)
Merge tag 'v1.6' into debian/sid
Added tag v1.6 for changeset 746517263955
Diffstat (limited to 'include/phat/representations/Unordered_map_container_traits.h')
-rw-r--r--include/phat/representations/Unordered_map_container_traits.h120
1 files changed, 120 insertions, 0 deletions
diff --git a/include/phat/representations/Unordered_map_container_traits.h b/include/phat/representations/Unordered_map_container_traits.h
new file mode 100644
index 0000000..0e54be6
--- /dev/null
+++ b/include/phat/representations/Unordered_map_container_traits.h
@@ -0,0 +1,120 @@
+/* Copyright 2013 IST Austria
+ Contributed by: Ulrich Bauer, Michael Kerber, Jan Reininghaus
+
+ This file is part of PHAT.
+
+ PHAT is free software: you can redistribute it and/or modify
+ it under the terms of the GNU Lesser General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+
+ PHAT 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 Lesser General Public License for more details.
+
+ You should have received a copy of the GNU Lesser General Public License
+ along with PHAT. If not, see <http://www.gnu.org/licenses/>. */
+
+#pragma once
+
+// This file requires c++11
+
+#include<phat/representations/Container_traits.h>
+
+#include<unordered_map>
+#include<mutex>
+
+namespace phat{
+
+template<class ColumnType>
+ class Column_container_traits< std::unordered_map<index,ColumnType> > {
+
+ protected:
+
+ index _size;
+
+ mutable std::mutex _mutex;
+
+ public:
+
+ typedef std::unordered_map<index,ColumnType> Column_container;
+
+ typedef ColumnType Column_type;
+
+ Column_type& col_at(Column_container& data, index idx) const {
+ _mutex.lock();
+ typename Column_container::iterator it = data.find(idx);
+ if(it==data.end()) {
+ std::pair<typename Column_container::iterator, bool> result
+ = data.insert(std::make_pair(idx,Column_type()));
+ it = result.first;
+ }
+ _mutex.unlock();
+ return it->second;
+ }
+
+ /*
+ const Column_type& col_at(const Column_container& data, index idx) const {
+ if(data.find(idx)==data.end()) {
+ data.insert(std::make_pair(idx,Column_type()));
+ }
+ return data.at(idx);
+ }
+ */
+
+ index get_size(const Column_container& data) const {
+ return _size;
+ }
+
+ void resize(Column_container& data, index nr_of_columns) {
+ _size = nr_of_columns;
+ }
+
+ };
+
+template<>
+ class Dimension_container_traits< std::unordered_map<index,index> > {
+
+ protected:
+
+ index _size;
+
+ mutable std::mutex _mutex;
+
+ public:
+
+ typedef std::unordered_map<index,index> Dimension_container;
+
+ index& dim_at(Dimension_container& data, index idx) const {
+ _mutex.lock();
+ typename Dimension_container::iterator it = data.find(idx);
+ if(it==data.end()) {
+ std::pair<typename Dimension_container::iterator, bool> result
+ = data.insert(std::make_pair(idx,0));
+ it = result.first;
+ }
+ _mutex.unlock();
+ return it->second;
+ }
+
+ /*
+ const index& dim_at(Dimension_container& data, index idx) const {
+ if(data.find(idx)==data.end()) {
+ data.insert(std::make_pair(idx,0));
+ }
+ return data.at(idx);
+ }
+ */
+
+ index get_size(const Dimension_container& data) const {
+ return _size;
+ }
+
+ void resize(Dimension_container& data, index nr_of_columns) {
+ _size = nr_of_columns;
+ }
+
+ };
+
+} // of namespace phat