ESPResSo
Extensible Simulation Package for Research on Soft Matter Systems
Loading...
Searching...
No Matches
ParticleRange.hpp
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2010-2022 The ESPResSo project
3
*
4
* This file is part of ESPResSo.
5
*
6
* ESPResSo is free software: you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation, either version 3 of the License, or
9
* (at your option) any later version.
10
*
11
* ESPResSo is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU General Public License for more details.
15
*
16
* You should have received a copy of the GNU General Public License
17
* along with this program. If not, see <http://www.gnu.org/licenses/>.
18
*/
19
20
#pragma once
21
22
#include "
CellParticleIterator.hpp
"
23
#include "
Particle.hpp
"
24
#include "
ParticleIterator.hpp
"
25
#include "
PropagationPredicate.hpp
"
26
#include "
cell_system/Cell.hpp
"
27
28
#include <boost/range/iterator_range.hpp>
29
30
#include <cassert>
31
32
/**
33
* @brief A range of particles.
34
*
35
* This is a boost::iterator_range with the addition that the
36
* size of the range is cached.
37
*/
38
class
ParticleRange
:
public
boost::iterator_range<CellParticleIterator> {
39
using
base_type = boost::iterator_range<CellParticleIterator>;
40
41
public
:
42
using
base_type::base_type;
43
44
base_type::size_type
size
()
const
{
45
if
(m_size < 0) {
46
m_size = distance(begin(), end());
47
}
48
49
return
assert(m_size >= 0),
static_cast<
base_type::size_type
>
(m_size);
50
}
51
52
template
<
typename
Predicate>
53
ParticleRangeFiltered<Predicate>
filter
(Predicate pred)
const
{
54
auto
const
predicate =
PropagationPredicate<Predicate>
(pred);
55
return
{boost::make_filter_iterator(predicate, begin(), end()),
56
boost::make_filter_iterator(predicate, end(), end())};
57
}
58
59
private
:
60
base_type::difference_type
mutable
m_size = -1;
61
};
CellParticleIterator.hpp
Cell.hpp
ParticleIterator.hpp
Particle.hpp
PropagationPredicate.hpp
ParticleRangeFiltered
Definition
PropagationPredicate.hpp:40
ParticleRange
A range of particles.
Definition
ParticleRange.hpp:38
ParticleRange::size
base_type::size_type size() const
Definition
ParticleRange.hpp:44
ParticleRange::filter
ParticleRangeFiltered< Predicate > filter(Predicate pred) const
Definition
ParticleRange.hpp:53
PropagationPredicate
Definition
PropagationPredicate.hpp:29
src
core
ParticleRange.hpp
Generated on Fri Nov 8 2024 02:12:53 for ESPResSo by
1.9.8