ESPResSo
Extensible Simulation Package for Research on Soft Matter Systems
Loading...
Searching...
No Matches
permute_ifield.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#ifndef UTILS_MATH_PERMUTE_IFIELD_HPP
20#define UTILS_MATH_PERMUTE_IFIELD_HPP
21
22namespace Utils {
23/** permute an integer array field of size size about permute positions. */
24inline void permute_ifield(int *field, int size, int permute) {
25 if (permute == 0)
26 return;
27 if (permute < 0)
28 permute = (size + permute);
29 while (permute > 0) {
30 int tmp = field[0];
31 for (int i = 1; i < size; i++)
32 field[i - 1] = field[i];
33 field[size - 1] = tmp;
34 permute--;
35 }
36}
37} // namespace Utils
38
39#endif
void permute_ifield(int *field, int size, int permute)
permute an integer array field of size size about permute positions.