BioDynaMo
v1.05.124-3123fa37
core
container
fixed_size_vector.h
Go to the documentation of this file.
1
// -----------------------------------------------------------------------------
2
//
3
// Copyright (C) 2021 CERN & University of Surrey for the benefit of the
4
// BioDynaMo collaboration. All Rights Reserved.
5
//
6
// Licensed under the Apache License, Version 2.0 (the "License");
7
// you may not use this file except in compliance with the License.
8
//
9
// See the LICENSE file distributed with this work for details.
10
// See the NOTICE file distributed with this work for additional information
11
// regarding copyright ownership.
12
//
13
// -----------------------------------------------------------------------------
14
15
#ifndef CORE_CONTAINER_FIXED_SIZE_VECTOR_H_
16
#define CORE_CONTAINER_FIXED_SIZE_VECTOR_H_
17
18
#include <algorithm>
19
#include <cassert>
20
#include <cstddef>
21
#include <initializer_list>
22
23
namespace
bdm
{
24
29
template
<
typename
T, std::
size_t
N>
30
class
FixedSizeVector
{
31
public
:
32
FixedSizeVector
() =
default
;
33
37
constexpr
FixedSizeVector
(
const
std::initializer_list<T>& l) {
38
assert(l.size() <= N);
39
auto
it = l.begin();
40
for
(
size_t
i = 0; i < N; i++) {
41
data_
[i] = *(it++);
42
}
43
size_
= l.size();
44
}
45
46
size_t
size
()
const
{
return
size_
; }
// NOLINT
47
48
const
T&
operator[]
(
size_t
idx)
const
{
return
data_
[idx]; }
49
50
T&
operator[]
(
size_t
idx) {
return
data_
[idx]; }
51
52
bool
operator==
(
const
FixedSizeVector
& other)
const
{
53
if
(
size_
!= other.
size_
) {
54
return
false
;
55
}
56
for
(
size_t
i = 0; i < std::min(
size_
, other.
size_
); i++) {
57
if
(
data_
[i] != other.
data_
[i]) {
58
return
false
;
59
}
60
}
61
return
true
;
62
}
63
64
FixedSizeVector
&
operator++
() {
65
#pragma omp simd
66
for
(
size_t
i = 0; i < N; i++) {
67
++
data_
[i];
68
}
69
return
*
this
;
70
}
71
72
void
clear
() {
size_
= 0; }
// NOLINT
73
74
void
push_back
(
const
T& value) {
// NOLINT
75
assert(
size_
< N);
76
data_
[
size_
++] = value;
77
}
78
79
const
T*
data
()
const
{
return
data_
; }
80
81
const
T*
begin
()
const
{
return
&(
data_
[0]); }
// NOLINT
82
const
T*
end
()
const
{
return
&(
data_
[
size_
]); }
// NOLINT
83
T*
begin
() {
return
&(
data_
[0]); }
// NOLINT
84
T*
end
() {
return
&(
data_
[
size_
]); }
// NOLINT
85
86
private
:
87
T
data_
[N];
88
std::size_t
size_
= 0;
89
};
90
91
}
// namespace bdm
92
93
#endif // CORE_CONTAINER_FIXED_SIZE_VECTOR_H_
bdm::FixedSizeVector::begin
const T * begin() const
Definition:
fixed_size_vector.h:81
bdm::FixedSizeVector::FixedSizeVector
constexpr FixedSizeVector(const std::initializer_list< T > &l)
Definition:
fixed_size_vector.h:37
bdm::FixedSizeVector
Definition:
fixed_size_vector.h:30
bdm::FixedSizeVector::size_
std::size_t size_
Definition:
fixed_size_vector.h:88
bdm
Definition:
agent.cc:39
bdm::FixedSizeVector::end
const T * end() const
Definition:
fixed_size_vector.h:82
bdm::FixedSizeVector::begin
T * begin()
Definition:
fixed_size_vector.h:83
bdm::FixedSizeVector::operator[]
const T & operator[](size_t idx) const
Definition:
fixed_size_vector.h:48
bdm::FixedSizeVector::push_back
void push_back(const T &value)
Definition:
fixed_size_vector.h:74
bdm::FixedSizeVector::end
T * end()
Definition:
fixed_size_vector.h:84
bdm::FixedSizeVector::operator[]
T & operator[](size_t idx)
Definition:
fixed_size_vector.h:50
bdm::FixedSizeVector::FixedSizeVector
FixedSizeVector()=default
bdm::FixedSizeVector::data_
T data_[N]
Definition:
fixed_size_vector.h:87
bdm::FixedSizeVector::size
size_t size() const
Definition:
fixed_size_vector.h:46
bdm::FixedSizeVector::clear
void clear()
Definition:
fixed_size_vector.h:72
bdm::FixedSizeVector::data
const T * data() const
Definition:
fixed_size_vector.h:79
bdm::FixedSizeVector::operator==
bool operator==(const FixedSizeVector &other) const
Definition:
fixed_size_vector.h:52
bdm::FixedSizeVector::operator++
FixedSizeVector & operator++()
Definition:
fixed_size_vector.h:64
Generated by
1.8.17