GCC Code Coverage Report


Directory: ../../../builds/dumux-repositories/
File: dumux/dumux/discretization/staggered/fvelementgeometry.hh
Date: 2025-04-12 19:19:20
Exec Total Coverage
Lines: 126 127 99.2%
Functions: 8 8 100.0%
Branches: 664 1346 49.3%

Line Branch Exec Source
1 // -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 // vi: set et ts=4 sw=4 sts=4:
3 //
4 // SPDX-FileCopyrightText: Copyright © DuMux Project contributors, see AUTHORS.md in root folder
5 // SPDX-License-Identifier: GPL-3.0-or-later
6 //
7 /*!
8 * \file
9 * \ingroup StaggeredDiscretization
10 * \copydoc Dumux::StaggeredFVElementGeometry
11 */
12 #ifndef DUMUX_DISCRETIZATION_STAGGERED_FV_ELEMENT_GEOMETRY_HH
13 #define DUMUX_DISCRETIZATION_STAGGERED_FV_ELEMENT_GEOMETRY_HH
14
15 #include <optional>
16 #include <bitset>
17
18 #include <dumux/common/indextraits.hh>
19 #include <dumux/discretization/cellcentered/tpfa/fvelementgeometry.hh>
20 #include <dumux/discretization/facecentered/staggered/normalaxis.hh>
21
22 namespace Dumux {
23
24 /*!
25 * \ingroup StaggeredDiscretization
26 * \brief Stencil-local finite volume geometry (scvs and scvfs) for staggered models
27 * This builds up the sub control volumes and sub control volume faces
28 * for each element in the local scope we are restricting to, e.g. stencil or element.
29 * \tparam GG the finite volume grid geometry type
30 * \tparam enableGridGeometryCache if the grid geometry is cached or not
31 * \note This class is specialized for versions with and without caching the fv geometries on the grid view
32 */
33 template<class GG, bool enableGridGeometryCache>
34 class StaggeredFVElementGeometry;
35
36 /*!
37 * \ingroup StaggeredDiscretization
38 * \brief Base class for the finite volume geometry vector for staggered models
39 * This locally builds up the sub control volumes and sub control volume faces
40 * for each element.
41 * Specialization for grid caching enabled
42 * \tparam GG the finite volume grid geometry type
43 */
44 template<class GG>
45
6/8
✓ Branch 0 taken 14160 times.
✓ Branch 1 taken 947532 times.
✓ Branch 3 taken 14160 times.
✓ Branch 4 taken 947532 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 413040 times.
✗ Branch 8 not taken.
✓ Branch 9 taken 413040 times.
2749464 class StaggeredFVElementGeometry<GG, true> : public CCTpfaFVElementGeometry<GG, true>
46 {
47 using ParentType = CCTpfaFVElementGeometry<GG, true>;
48 using GridView = typename GG::GridView;
49 using GridIndexType = typename IndexTraits<GridView>::GridIndex;
50 using LocalIndexType = typename IndexTraits<GridView>::LocalIndex;
51 public:
52 //! export type of the element
53 using Element = typename GridView::template Codim<0>::Entity;
54 //! export type of subcontrol volume face
55 using SubControlVolumeFace = typename GG::SubControlVolumeFace;
56
57
12/23
✓ Branch 1 taken 1331 times.
✓ Branch 2 taken 1 times.
✓ Branch 5 taken 51 times.
✗ Branch 6 not taken.
✓ Branch 8 taken 18 times.
✓ Branch 9 taken 1 times.
✓ Branch 12 taken 419 times.
✓ Branch 13 taken 79 times.
✓ Branch 15 taken 1087 times.
✗ Branch 16 not taken.
✗ Branch 20 not taken.
✗ Branch 21 not taken.
✓ Branch 23 taken 63 times.
✗ Branch 24 not taken.
✓ Branch 10 taken 79 times.
✗ Branch 3 not taken.
✓ Branch 11 taken 18 times.
✓ Branch 18 taken 669 times.
✗ Branch 19 not taken.
✗ Branch 27 not taken.
✗ Branch 28 not taken.
✗ Branch 14 not taken.
✗ Branch 17 not taken.
66143 using ParentType::ParentType;
58
59 //! Constructor getting a auxiliary cell center of face specific FvGridGeometry type.
60 //! Needed for the multi-domain framework.
61 template<class CellCenterOrFaceFVGridGeometry>
62 2721314 StaggeredFVElementGeometry(const CellCenterOrFaceFVGridGeometry& gridGeometry)
63
6/12
✓ Branch 1 taken 947549 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 947549 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 413074 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 413074 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 51 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 17 times.
✗ Branch 17 not taken.
2721314 : ParentType(gridGeometry.actualGridGeometry()) {}
64
65 //! Get a sub control volume face with an element index and a local scvf index
66 using ParentType::scvf;
67 1437368117 const SubControlVolumeFace& scvf(GridIndexType eIdx, LocalIndexType localScvfIdx) const
68 {
69
14/17
✓ Branch 0 taken 2400 times.
✓ Branch 1 taken 600 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 9 taken 346772 times.
✓ Branch 10 taken 280656308 times.
✓ Branch 12 taken 3895241 times.
✓ Branch 13 taken 285919951 times.
✓ Branch 15 taken 14778138 times.
✓ Branch 16 taken 207415580 times.
✓ Branch 17 taken 69686676 times.
✓ Branch 18 taken 3851288 times.
✗ Branch 11 not taken.
✓ Branch 14 taken 2 times.
✓ Branch 19 taken 138804 times.
✓ Branch 20 taken 1375652 times.
✓ Branch 21 taken 482220 times.
1437314239 return this->gridGeometry().scvf(eIdx, localScvfIdx);
70 }
71 };
72
73 /*!
74 * \ingroup StaggeredDiscretization
75 * \brief Base class for the finite volume geometry vector for staggered models
76 * This locally builds up the sub control volumes and sub control volume faces
77 * for each element.
78 * Specialization for grid caching disabled
79 * \tparam GG the finite volume grid geometry type
80 */
81 template<class GG>
82 class StaggeredFVElementGeometry<GG, false>
83 {
84 using ThisType = StaggeredFVElementGeometry<GG, false>;
85 using GridView = typename GG::GridView;
86 using GridIndexType = typename IndexTraits<GridView>::GridIndex;
87 using LocalIndexType = typename IndexTraits<GridView>::LocalIndex;
88 public:
89 //! export type of the element
90 using Element = typename GridView::template Codim<0>::Entity;
91 //! export type of subcontrol volume
92 using SubControlVolume = typename GG::SubControlVolume;
93 //! export type of subcontrol volume face
94 using SubControlVolumeFace = typename GG::SubControlVolumeFace;
95 //! export type of finite volume grid geometry
96 using GridGeometry = GG;
97
98 //! Constructor getting a auxiliary cell center of face specific FvGridGeometry type.
99 //! Needed for the multi-domain framework.
100 template<class CellCenterOrFaceFVGridGeometry>
101 StaggeredFVElementGeometry(const CellCenterOrFaceFVGridGeometry& gridGeometry)
102 : gridGeometryPtr_(&gridGeometry.actualGridGeometry()) {}
103
104 //! Constructor
105 213 StaggeredFVElementGeometry(const GridGeometry& gridGeometry)
106
189/426
✓ Branch 1 taken 1 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 1 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 1 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 1 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 1 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 1 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 1 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 1 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 1 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 1 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 1 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 1 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 1 times.
✗ Branch 38 not taken.
✓ Branch 40 taken 1 times.
✗ Branch 41 not taken.
✓ Branch 43 taken 1 times.
✗ Branch 44 not taken.
✓ Branch 46 taken 1 times.
✗ Branch 47 not taken.
✓ Branch 49 taken 1 times.
✗ Branch 50 not taken.
✓ Branch 52 taken 1 times.
✗ Branch 53 not taken.
✓ Branch 55 taken 1 times.
✗ Branch 56 not taken.
✓ Branch 58 taken 1 times.
✗ Branch 59 not taken.
✓ Branch 61 taken 1 times.
✗ Branch 62 not taken.
✓ Branch 64 taken 1 times.
✗ Branch 65 not taken.
✓ Branch 67 taken 1 times.
✗ Branch 68 not taken.
✓ Branch 70 taken 1 times.
✗ Branch 71 not taken.
✓ Branch 73 taken 1 times.
✗ Branch 74 not taken.
✓ Branch 76 taken 1 times.
✗ Branch 77 not taken.
✓ Branch 79 taken 1 times.
✗ Branch 80 not taken.
✓ Branch 82 taken 1 times.
✗ Branch 83 not taken.
✓ Branch 85 taken 1 times.
✗ Branch 86 not taken.
✓ Branch 88 taken 1 times.
✗ Branch 89 not taken.
✓ Branch 91 taken 1 times.
✗ Branch 92 not taken.
✓ Branch 94 taken 1 times.
✗ Branch 95 not taken.
✓ Branch 97 taken 1 times.
✗ Branch 98 not taken.
✓ Branch 100 taken 1 times.
✗ Branch 101 not taken.
✓ Branch 103 taken 1 times.
✗ Branch 104 not taken.
✓ Branch 106 taken 1 times.
✗ Branch 107 not taken.
✓ Branch 109 taken 1 times.
✗ Branch 110 not taken.
✓ Branch 112 taken 1 times.
✗ Branch 113 not taken.
✓ Branch 115 taken 1 times.
✗ Branch 116 not taken.
✓ Branch 118 taken 1 times.
✗ Branch 119 not taken.
✓ Branch 121 taken 1 times.
✗ Branch 122 not taken.
✓ Branch 124 taken 1 times.
✗ Branch 125 not taken.
✓ Branch 127 taken 1 times.
✗ Branch 128 not taken.
✓ Branch 130 taken 1 times.
✗ Branch 131 not taken.
✓ Branch 133 taken 1 times.
✗ Branch 134 not taken.
✗ Branch 136 not taken.
✗ Branch 137 not taken.
✗ Branch 139 not taken.
✗ Branch 140 not taken.
✗ Branch 142 not taken.
✗ Branch 143 not taken.
✗ Branch 145 not taken.
✗ Branch 146 not taken.
✗ Branch 148 not taken.
✗ Branch 149 not taken.
✗ Branch 151 not taken.
✗ Branch 152 not taken.
✗ Branch 154 not taken.
✗ Branch 155 not taken.
✗ Branch 157 not taken.
✗ Branch 158 not taken.
✗ Branch 160 not taken.
✗ Branch 161 not taken.
✗ Branch 163 not taken.
✗ Branch 164 not taken.
✗ Branch 166 not taken.
✗ Branch 167 not taken.
✗ Branch 169 not taken.
✗ Branch 170 not taken.
✓ Branch 172 taken 1 times.
✗ Branch 173 not taken.
✓ Branch 175 taken 1 times.
✗ Branch 176 not taken.
✓ Branch 178 taken 1 times.
✗ Branch 179 not taken.
✓ Branch 181 taken 1 times.
✗ Branch 182 not taken.
✓ Branch 184 taken 1 times.
✗ Branch 185 not taken.
✓ Branch 187 taken 1 times.
✗ Branch 188 not taken.
✓ Branch 190 taken 1 times.
✗ Branch 191 not taken.
✓ Branch 193 taken 1 times.
✗ Branch 194 not taken.
✓ Branch 196 taken 1 times.
✗ Branch 197 not taken.
✓ Branch 199 taken 1 times.
✗ Branch 200 not taken.
✓ Branch 202 taken 1 times.
✗ Branch 203 not taken.
✓ Branch 205 taken 1 times.
✗ Branch 206 not taken.
✓ Branch 208 taken 1 times.
✗ Branch 209 not taken.
✓ Branch 211 taken 1 times.
✗ Branch 212 not taken.
✓ Branch 214 taken 1 times.
✗ Branch 215 not taken.
✓ Branch 217 taken 1 times.
✗ Branch 218 not taken.
✓ Branch 220 taken 1 times.
✗ Branch 221 not taken.
✓ Branch 223 taken 1 times.
✗ Branch 224 not taken.
✓ Branch 226 taken 1 times.
✗ Branch 227 not taken.
✓ Branch 229 taken 1 times.
✗ Branch 230 not taken.
✓ Branch 232 taken 1 times.
✗ Branch 233 not taken.
✓ Branch 235 taken 1 times.
✗ Branch 236 not taken.
✓ Branch 238 taken 1 times.
✗ Branch 239 not taken.
✓ Branch 241 taken 1 times.
✗ Branch 242 not taken.
✓ Branch 244 taken 1 times.
✗ Branch 245 not taken.
✓ Branch 247 taken 1 times.
✗ Branch 248 not taken.
✓ Branch 250 taken 1 times.
✗ Branch 251 not taken.
✓ Branch 253 taken 1 times.
✗ Branch 254 not taken.
✓ Branch 256 taken 1 times.
✗ Branch 257 not taken.
✓ Branch 259 taken 1 times.
✗ Branch 260 not taken.
✓ Branch 262 taken 1 times.
✗ Branch 263 not taken.
✓ Branch 265 taken 1 times.
✗ Branch 266 not taken.
✓ Branch 268 taken 1 times.
✗ Branch 269 not taken.
✓ Branch 271 taken 1 times.
✗ Branch 272 not taken.
✓ Branch 274 taken 1 times.
✗ Branch 275 not taken.
✓ Branch 277 taken 1 times.
✗ Branch 278 not taken.
✗ Branch 280 not taken.
✗ Branch 281 not taken.
✓ Branch 283 taken 1 times.
✗ Branch 284 not taken.
✓ Branch 286 taken 1 times.
✗ Branch 287 not taken.
✓ Branch 289 taken 1 times.
✗ Branch 290 not taken.
✓ Branch 292 taken 1 times.
✗ Branch 293 not taken.
✗ Branch 295 not taken.
✗ Branch 296 not taken.
✓ Branch 298 taken 1 times.
✗ Branch 299 not taken.
✓ Branch 301 taken 1 times.
✗ Branch 302 not taken.
✓ Branch 304 taken 1 times.
✗ Branch 305 not taken.
✓ Branch 307 taken 1 times.
✗ Branch 308 not taken.
✗ Branch 310 not taken.
✗ Branch 311 not taken.
✓ Branch 313 taken 1 times.
✗ Branch 314 not taken.
✓ Branch 316 taken 1 times.
✗ Branch 317 not taken.
✓ Branch 319 taken 1 times.
✗ Branch 320 not taken.
✓ Branch 322 taken 1 times.
✗ Branch 323 not taken.
✗ Branch 325 not taken.
✗ Branch 326 not taken.
✓ Branch 328 taken 1 times.
✗ Branch 329 not taken.
✓ Branch 331 taken 1 times.
✗ Branch 332 not taken.
✓ Branch 334 taken 1 times.
✗ Branch 335 not taken.
✓ Branch 337 taken 1 times.
✗ Branch 338 not taken.
✓ Branch 340 taken 1 times.
✗ Branch 341 not taken.
✓ Branch 343 taken 1 times.
✗ Branch 344 not taken.
✓ Branch 346 taken 1 times.
✗ Branch 347 not taken.
✓ Branch 349 taken 1 times.
✗ Branch 350 not taken.
✓ Branch 352 taken 1 times.
✗ Branch 353 not taken.
✓ Branch 355 taken 1 times.
✗ Branch 356 not taken.
✓ Branch 358 taken 1 times.
✗ Branch 359 not taken.
✓ Branch 361 taken 1 times.
✗ Branch 362 not taken.
✓ Branch 364 taken 1 times.
✗ Branch 365 not taken.
✓ Branch 367 taken 1 times.
✗ Branch 368 not taken.
✓ Branch 370 taken 1 times.
✗ Branch 371 not taken.
✓ Branch 373 taken 1 times.
✗ Branch 374 not taken.
✓ Branch 376 taken 1 times.
✗ Branch 377 not taken.
✓ Branch 379 taken 1 times.
✗ Branch 380 not taken.
✓ Branch 382 taken 1 times.
✗ Branch 383 not taken.
✓ Branch 385 taken 1 times.
✗ Branch 386 not taken.
✗ Branch 388 not taken.
✗ Branch 389 not taken.
✓ Branch 391 taken 1 times.
✗ Branch 392 not taken.
✓ Branch 394 taken 1 times.
✗ Branch 395 not taken.
✓ Branch 397 taken 1 times.
✗ Branch 398 not taken.
✓ Branch 400 taken 1 times.
✗ Branch 401 not taken.
✗ Branch 403 not taken.
✗ Branch 404 not taken.
✓ Branch 406 taken 1 times.
✗ Branch 407 not taken.
✓ Branch 409 taken 1 times.
✗ Branch 410 not taken.
✓ Branch 412 taken 1 times.
✗ Branch 413 not taken.
✓ Branch 415 taken 1 times.
✗ Branch 416 not taken.
✗ Branch 418 not taken.
✗ Branch 419 not taken.
✓ Branch 421 taken 1 times.
✗ Branch 422 not taken.
✓ Branch 424 taken 1 times.
✗ Branch 425 not taken.
✓ Branch 427 taken 1 times.
✗ Branch 428 not taken.
✓ Branch 430 taken 1 times.
✗ Branch 431 not taken.
✗ Branch 433 not taken.
✗ Branch 434 not taken.
✗ Branch 436 not taken.
✗ Branch 437 not taken.
✗ Branch 439 not taken.
✗ Branch 440 not taken.
✗ Branch 442 not taken.
✗ Branch 443 not taken.
✗ Branch 445 not taken.
✗ Branch 446 not taken.
✓ Branch 448 taken 1 times.
✗ Branch 449 not taken.
✓ Branch 451 taken 2 times.
✗ Branch 452 not taken.
✓ Branch 454 taken 1 times.
✗ Branch 455 not taken.
✓ Branch 457 taken 1 times.
✗ Branch 458 not taken.
✓ Branch 460 taken 2 times.
✗ Branch 461 not taken.
✓ Branch 463 taken 1 times.
✗ Branch 464 not taken.
✓ Branch 466 taken 1 times.
✗ Branch 467 not taken.
✓ Branch 469 taken 2 times.
✗ Branch 470 not taken.
✓ Branch 472 taken 1 times.
✗ Branch 473 not taken.
✓ Branch 475 taken 1 times.
✗ Branch 476 not taken.
✓ Branch 478 taken 2 times.
✗ Branch 479 not taken.
✓ Branch 481 taken 1 times.
✗ Branch 482 not taken.
✓ Branch 484 taken 1 times.
✗ Branch 485 not taken.
✓ Branch 487 taken 2 times.
✗ Branch 488 not taken.
✓ Branch 490 taken 1 times.
✗ Branch 491 not taken.
✓ Branch 493 taken 1 times.
✗ Branch 494 not taken.
✓ Branch 496 taken 2 times.
✗ Branch 497 not taken.
✓ Branch 499 taken 1 times.
✗ Branch 500 not taken.
✓ Branch 502 taken 1 times.
✗ Branch 503 not taken.
✓ Branch 505 taken 2 times.
✗ Branch 506 not taken.
✓ Branch 508 taken 1 times.
✗ Branch 509 not taken.
✓ Branch 511 taken 1 times.
✗ Branch 512 not taken.
✓ Branch 514 taken 2 times.
✗ Branch 515 not taken.
✓ Branch 517 taken 1 times.
✗ Branch 518 not taken.
✓ Branch 520 taken 1 times.
✗ Branch 521 not taken.
✓ Branch 523 taken 2 times.
✗ Branch 524 not taken.
✓ Branch 526 taken 1 times.
✗ Branch 527 not taken.
✓ Branch 529 taken 1 times.
✗ Branch 530 not taken.
✓ Branch 532 taken 2 times.
✗ Branch 533 not taken.
✓ Branch 535 taken 1 times.
✗ Branch 536 not taken.
✓ Branch 538 taken 1 times.
✗ Branch 539 not taken.
✓ Branch 541 taken 2 times.
✗ Branch 542 not taken.
✓ Branch 544 taken 1 times.
✗ Branch 545 not taken.
✓ Branch 547 taken 1 times.
✗ Branch 548 not taken.
✓ Branch 550 taken 2 times.
✗ Branch 551 not taken.
✓ Branch 553 taken 1 times.
✗ Branch 554 not taken.
✓ Branch 556 taken 1 times.
✗ Branch 557 not taken.
✓ Branch 559 taken 2 times.
✗ Branch 560 not taken.
✓ Branch 562 taken 1 times.
✗ Branch 563 not taken.
✓ Branch 565 taken 1 times.
✗ Branch 566 not taken.
✓ Branch 568 taken 2 times.
✗ Branch 569 not taken.
✓ Branch 571 taken 1 times.
✗ Branch 572 not taken.
✓ Branch 574 taken 1 times.
✗ Branch 575 not taken.
✓ Branch 577 taken 2 times.
✗ Branch 578 not taken.
✓ Branch 580 taken 1 times.
✗ Branch 581 not taken.
✓ Branch 583 taken 1 times.
✗ Branch 584 not taken.
✓ Branch 586 taken 2 times.
✗ Branch 587 not taken.
✓ Branch 589 taken 1 times.
✗ Branch 590 not taken.
✓ Branch 592 taken 1 times.
✗ Branch 593 not taken.
✓ Branch 595 taken 2 times.
✗ Branch 596 not taken.
✓ Branch 598 taken 1 times.
✗ Branch 599 not taken.
✓ Branch 601 taken 2 times.
✗ Branch 602 not taken.
✓ Branch 604 taken 1 times.
✗ Branch 605 not taken.
✓ Branch 607 taken 2 times.
✗ Branch 608 not taken.
✓ Branch 610 taken 1 times.
✗ Branch 611 not taken.
✓ Branch 613 taken 2 times.
✗ Branch 614 not taken.
✓ Branch 616 taken 1 times.
✗ Branch 617 not taken.
✓ Branch 619 taken 2 times.
✗ Branch 620 not taken.
✓ Branch 622 taken 1 times.
✗ Branch 623 not taken.
✓ Branch 625 taken 2 times.
✗ Branch 626 not taken.
✓ Branch 628 taken 1 times.
✗ Branch 629 not taken.
✓ Branch 631 taken 2 times.
✗ Branch 632 not taken.
✓ Branch 634 taken 1 times.
✗ Branch 635 not taken.
✓ Branch 637 taken 2 times.
✗ Branch 638 not taken.
213 : gridGeometryPtr_(&gridGeometry) {}
107
108 //! Get a sub control volume face with an element index and a local scvf index
109 4200 const SubControlVolumeFace& scvf(GridIndexType eIdx, LocalIndexType localScvfIdx) const
110 {
111 4200 return scvf(this->gridGeometry().localToGlobalScvfIndex(eIdx, localScvfIdx));
112 }
113
114 //! Get an element sub control volume with a global scv index
115 //! We separate element and neighbor scvs to speed up mapping
116 3120 const SubControlVolume& scv(GridIndexType scvIdx) const
117 {
118
72/184
✗ Branch 0 not taken.
✗ Branch 1 not taken.
✓ Branch 2 taken 25 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 25 times.
✓ Branch 5 taken 80 times.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✓ Branch 8 taken 25 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 25 times.
✓ Branch 11 taken 80 times.
✗ Branch 12 not taken.
✗ Branch 13 not taken.
✓ Branch 14 taken 25 times.
✗ Branch 15 not taken.
✓ Branch 16 taken 25 times.
✓ Branch 17 taken 80 times.
✗ Branch 18 not taken.
✗ Branch 19 not taken.
✓ Branch 20 taken 25 times.
✗ Branch 21 not taken.
✓ Branch 22 taken 25 times.
✓ Branch 23 taken 80 times.
✗ Branch 24 not taken.
✗ Branch 25 not taken.
✓ Branch 26 taken 25 times.
✗ Branch 27 not taken.
✓ Branch 28 taken 25 times.
✓ Branch 29 taken 80 times.
✗ Branch 30 not taken.
✗ Branch 31 not taken.
✓ Branch 32 taken 25 times.
✗ Branch 33 not taken.
✓ Branch 34 taken 25 times.
✓ Branch 35 taken 80 times.
✗ Branch 36 not taken.
✗ Branch 37 not taken.
✓ Branch 38 taken 25 times.
✗ Branch 39 not taken.
✓ Branch 40 taken 25 times.
✓ Branch 41 taken 80 times.
✗ Branch 42 not taken.
✗ Branch 43 not taken.
✓ Branch 44 taken 25 times.
✗ Branch 45 not taken.
✓ Branch 46 taken 25 times.
✓ Branch 47 taken 80 times.
✗ Branch 48 not taken.
✗ Branch 49 not taken.
✓ Branch 50 taken 25 times.
✗ Branch 51 not taken.
✓ Branch 52 taken 25 times.
✓ Branch 53 taken 80 times.
✗ Branch 54 not taken.
✗ Branch 55 not taken.
✓ Branch 56 taken 25 times.
✗ Branch 57 not taken.
✓ Branch 58 taken 25 times.
✓ Branch 59 taken 80 times.
✗ Branch 60 not taken.
✗ Branch 61 not taken.
✓ Branch 62 taken 25 times.
✗ Branch 63 not taken.
✓ Branch 64 taken 25 times.
✓ Branch 65 taken 80 times.
✗ Branch 66 not taken.
✗ Branch 67 not taken.
✓ Branch 68 taken 25 times.
✗ Branch 69 not taken.
✓ Branch 70 taken 25 times.
✓ Branch 71 taken 80 times.
✗ Branch 72 not taken.
✗ Branch 73 not taken.
✓ Branch 74 taken 25 times.
✗ Branch 75 not taken.
✓ Branch 76 taken 25 times.
✓ Branch 77 taken 80 times.
✗ Branch 78 not taken.
✗ Branch 79 not taken.
✓ Branch 80 taken 25 times.
✗ Branch 81 not taken.
✓ Branch 82 taken 25 times.
✓ Branch 83 taken 80 times.
✗ Branch 84 not taken.
✗ Branch 85 not taken.
✓ Branch 86 taken 25 times.
✗ Branch 87 not taken.
✓ Branch 88 taken 25 times.
✓ Branch 89 taken 80 times.
✗ Branch 90 not taken.
✗ Branch 91 not taken.
✓ Branch 92 taken 25 times.
✗ Branch 93 not taken.
✓ Branch 94 taken 25 times.
✓ Branch 95 taken 80 times.
✗ Branch 96 not taken.
✗ Branch 97 not taken.
✓ Branch 98 taken 25 times.
✗ Branch 99 not taken.
✓ Branch 100 taken 25 times.
✓ Branch 101 taken 80 times.
✗ Branch 102 not taken.
✗ Branch 103 not taken.
✓ Branch 104 taken 25 times.
✗ Branch 105 not taken.
✓ Branch 106 taken 25 times.
✓ Branch 107 taken 80 times.
✗ Branch 108 not taken.
✗ Branch 109 not taken.
✓ Branch 110 taken 25 times.
✗ Branch 111 not taken.
✓ Branch 112 taken 25 times.
✓ Branch 113 taken 80 times.
✗ Branch 114 not taken.
✗ Branch 115 not taken.
✓ Branch 116 taken 25 times.
✗ Branch 117 not taken.
✓ Branch 118 taken 25 times.
✓ Branch 119 taken 80 times.
✗ Branch 120 not taken.
✗ Branch 121 not taken.
✓ Branch 122 taken 25 times.
✗ Branch 123 not taken.
✓ Branch 124 taken 25 times.
✓ Branch 125 taken 80 times.
✗ Branch 126 not taken.
✗ Branch 127 not taken.
✓ Branch 128 taken 25 times.
✗ Branch 129 not taken.
✓ Branch 130 taken 25 times.
✓ Branch 131 taken 80 times.
✗ Branch 132 not taken.
✗ Branch 133 not taken.
✓ Branch 134 taken 25 times.
✗ Branch 135 not taken.
✓ Branch 136 taken 25 times.
✓ Branch 137 taken 80 times.
✗ Branch 138 not taken.
✗ Branch 139 not taken.
✓ Branch 140 taken 25 times.
✗ Branch 141 not taken.
✓ Branch 142 taken 25 times.
✓ Branch 143 taken 80 times.
✗ Branch 144 not taken.
✗ Branch 145 not taken.
✗ Branch 146 not taken.
✗ Branch 147 not taken.
✗ Branch 148 not taken.
✗ Branch 149 not taken.
✗ Branch 150 not taken.
✗ Branch 151 not taken.
✗ Branch 152 not taken.
✗ Branch 153 not taken.
✗ Branch 154 not taken.
✗ Branch 155 not taken.
✗ Branch 156 not taken.
✗ Branch 157 not taken.
✗ Branch 158 not taken.
✗ Branch 159 not taken.
✗ Branch 160 not taken.
✗ Branch 161 not taken.
✗ Branch 162 not taken.
✗ Branch 163 not taken.
✗ Branch 164 not taken.
✗ Branch 165 not taken.
✗ Branch 166 not taken.
✗ Branch 167 not taken.
✗ Branch 168 not taken.
✗ Branch 169 not taken.
✗ Branch 170 not taken.
✗ Branch 171 not taken.
✗ Branch 172 not taken.
✗ Branch 173 not taken.
✗ Branch 174 not taken.
✗ Branch 175 not taken.
✗ Branch 176 not taken.
✗ Branch 177 not taken.
✗ Branch 178 not taken.
✗ Branch 179 not taken.
✗ Branch 180 not taken.
✗ Branch 181 not taken.
✗ Branch 182 not taken.
✗ Branch 183 not taken.
3120 if (scvIdx == scvIndices_[0])
119 1200 return scvs_[0];
120 else
121 1920 return neighborScvs_[findLocalIndex_(scvIdx, neighborScvIndices_)];
122 }
123
124 //! Get an element sub control volume face with a global scvf index
125 //! We separate element and neighbor scvfs to speed up mapping
126 4200 const SubControlVolumeFace& scvf(GridIndexType scvfIdx) const
127 {
128
1/2
✓ Branch 0 taken 4200 times.
✗ Branch 1 not taken.
4200 auto it = std::find(scvfIndices_.begin(), scvfIndices_.end(), scvfIdx);
129
1/2
✓ Branch 0 taken 4200 times.
✗ Branch 1 not taken.
4200 if (it != scvfIndices_.end())
130 4200 return scvfs_[std::distance(scvfIndices_.begin(), it)];
131 else
132 return neighborScvfs_[findLocalIndex_(scvfIdx, neighborScvfIndices_)];
133 }
134
135 //! iterator range for sub control volumes. Iterates over
136 //! all scvs of the bound element (not including neighbor scvs)
137 //! This is a free function found by means of ADL
138 //! To iterate over all sub control volumes of this FVElementGeometry use
139 //! for (auto&& scv : scvs(fvGeometry))
140 friend inline Dune::IteratorRange<typename std::array<SubControlVolume, 1>::const_iterator>
141 600 scvs(const ThisType& g)
142 {
143 using IteratorType = typename std::array<SubControlVolume, 1>::const_iterator;
144 600 return Dune::IteratorRange<IteratorType>(g.scvs_.begin(), g.scvs_.end());
145 }
146
147 //! iterator range for sub control volumes faces. Iterates over
148 //! all scvfs of the bound element (not including neighbor scvfs)
149 //! This is a free function found by means of ADL
150 //! To iterate over all sub control volume faces of this FVElementGeometry use
151 //! for (auto&& scvf : scvfs(fvGeometry))
152 friend inline Dune::IteratorRange<typename std::vector<SubControlVolumeFace>::const_iterator>
153 4849 scvfs(const ThisType& g)
154 {
155 using IteratorType = typename std::vector<SubControlVolumeFace>::const_iterator;
156 4849 return Dune::IteratorRange<IteratorType>(g.scvfs_.begin(), g.scvfs_.end());
157 }
158
159 //! number of sub control volumes in this fv element geometry
160 std::size_t numScv() const
161 { return scvs_.size(); }
162
163 //! number of sub control volumes in this fv element geometry
164 600 std::size_t numScvf() const
165 600 { return scvfs_.size(); }
166
167 /*!
168 * \brief bind the local view (r-value overload)
169 * This overload is called when an instance of this class is a temporary in the usage context
170 * This allows a usage like this: `const auto view = localView(...).bind(element);`
171 */
172 StaggeredFVElementGeometry bind(const Element& element) &&
173 {
174 this->bind_(element);
175 return std::move(*this);
176 }
177
178 //! bind this local view to a specific element (full stencil)
179 1200 void bind(const Element& element) &
180
48/96
✓ Branch 1 taken 25 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 25 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 25 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 25 times.
✗ Branch 11 not taken.
✓ Branch 13 taken 25 times.
✗ Branch 14 not taken.
✓ Branch 16 taken 25 times.
✗ Branch 17 not taken.
✓ Branch 19 taken 25 times.
✗ Branch 20 not taken.
✓ Branch 22 taken 25 times.
✗ Branch 23 not taken.
✓ Branch 25 taken 25 times.
✗ Branch 26 not taken.
✓ Branch 28 taken 25 times.
✗ Branch 29 not taken.
✓ Branch 31 taken 25 times.
✗ Branch 32 not taken.
✓ Branch 34 taken 25 times.
✗ Branch 35 not taken.
✓ Branch 37 taken 25 times.
✗ Branch 38 not taken.
✓ Branch 40 taken 25 times.
✗ Branch 41 not taken.
✓ Branch 43 taken 25 times.
✗ Branch 44 not taken.
✓ Branch 46 taken 25 times.
✗ Branch 47 not taken.
✓ Branch 49 taken 25 times.
✗ Branch 50 not taken.
✓ Branch 52 taken 25 times.
✗ Branch 53 not taken.
✓ Branch 55 taken 25 times.
✗ Branch 56 not taken.
✓ Branch 58 taken 25 times.
✗ Branch 59 not taken.
✓ Branch 61 taken 25 times.
✗ Branch 62 not taken.
✓ Branch 64 taken 25 times.
✗ Branch 65 not taken.
✓ Branch 67 taken 25 times.
✗ Branch 68 not taken.
✓ Branch 70 taken 25 times.
✗ Branch 71 not taken.
✓ Branch 73 taken 25 times.
✗ Branch 74 not taken.
✓ Branch 76 taken 25 times.
✗ Branch 77 not taken.
✓ Branch 79 taken 25 times.
✗ Branch 80 not taken.
✓ Branch 82 taken 25 times.
✗ Branch 83 not taken.
✓ Branch 85 taken 25 times.
✗ Branch 86 not taken.
✓ Branch 88 taken 25 times.
✗ Branch 89 not taken.
✓ Branch 91 taken 25 times.
✗ Branch 92 not taken.
✓ Branch 94 taken 25 times.
✗ Branch 95 not taken.
✓ Branch 97 taken 25 times.
✗ Branch 98 not taken.
✓ Branch 100 taken 25 times.
✗ Branch 101 not taken.
✓ Branch 103 taken 25 times.
✗ Branch 104 not taken.
✓ Branch 106 taken 25 times.
✗ Branch 107 not taken.
✓ Branch 109 taken 25 times.
✗ Branch 110 not taken.
✓ Branch 112 taken 25 times.
✗ Branch 113 not taken.
✓ Branch 115 taken 25 times.
✗ Branch 116 not taken.
✓ Branch 118 taken 25 times.
✗ Branch 119 not taken.
✓ Branch 121 taken 25 times.
✗ Branch 122 not taken.
✓ Branch 124 taken 25 times.
✗ Branch 125 not taken.
✓ Branch 127 taken 25 times.
✗ Branch 128 not taken.
✓ Branch 130 taken 25 times.
✗ Branch 131 not taken.
✓ Branch 133 taken 25 times.
✗ Branch 134 not taken.
✓ Branch 136 taken 25 times.
✗ Branch 137 not taken.
✓ Branch 139 taken 25 times.
✗ Branch 140 not taken.
✓ Branch 142 taken 25 times.
✗ Branch 143 not taken.
1200 { this->bind_(element); }
181
182 /*!
183 * \brief bind the local view (r-value overload)
184 * This overload is called when an instance of this class is a temporary in the usage context
185 * This allows a usage like this: `const auto view = localView(...).bindElement(element);`
186 */
187 StaggeredFVElementGeometry bindElement(const Element& element) &&
188 {
189 this->bindElement_(element);
190 return std::move(*this);
191 }
192
193 //! bind this local view to a specific element
194 3745 void bindElement(const Element& element) &
195
145/386
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 7 not taken.
✗ Branch 8 not taken.
✗ Branch 10 not taken.
✗ Branch 11 not taken.
✗ Branch 13 not taken.
✗ Branch 14 not taken.
✗ Branch 16 not taken.
✗ Branch 17 not taken.
✗ Branch 19 not taken.
✗ Branch 20 not taken.
✗ Branch 22 not taken.
✗ Branch 23 not taken.
✗ Branch 25 not taken.
✗ Branch 26 not taken.
✗ Branch 28 not taken.
✗ Branch 29 not taken.
✗ Branch 31 not taken.
✗ Branch 32 not taken.
✗ Branch 34 not taken.
✗ Branch 35 not taken.
✗ Branch 37 not taken.
✗ Branch 38 not taken.
✗ Branch 40 not taken.
✗ Branch 41 not taken.
✗ Branch 43 not taken.
✗ Branch 44 not taken.
✗ Branch 46 not taken.
✗ Branch 47 not taken.
✗ Branch 49 not taken.
✗ Branch 50 not taken.
✗ Branch 52 not taken.
✗ Branch 53 not taken.
✗ Branch 55 not taken.
✗ Branch 56 not taken.
✗ Branch 58 not taken.
✗ Branch 59 not taken.
✗ Branch 61 not taken.
✗ Branch 62 not taken.
✗ Branch 64 not taken.
✗ Branch 65 not taken.
✗ Branch 67 not taken.
✗ Branch 68 not taken.
✗ Branch 70 not taken.
✗ Branch 71 not taken.
✓ Branch 73 taken 25 times.
✗ Branch 74 not taken.
✓ Branch 76 taken 25 times.
✗ Branch 77 not taken.
✓ Branch 79 taken 25 times.
✗ Branch 80 not taken.
✓ Branch 82 taken 25 times.
✗ Branch 83 not taken.
✓ Branch 85 taken 25 times.
✗ Branch 86 not taken.
✓ Branch 88 taken 25 times.
✗ Branch 89 not taken.
✓ Branch 91 taken 25 times.
✗ Branch 92 not taken.
✓ Branch 94 taken 25 times.
✗ Branch 95 not taken.
✓ Branch 97 taken 25 times.
✗ Branch 98 not taken.
✓ Branch 100 taken 25 times.
✗ Branch 101 not taken.
✓ Branch 103 taken 25 times.
✗ Branch 104 not taken.
✓ Branch 106 taken 25 times.
✗ Branch 107 not taken.
✓ Branch 109 taken 25 times.
✗ Branch 110 not taken.
✓ Branch 112 taken 25 times.
✗ Branch 113 not taken.
✓ Branch 115 taken 25 times.
✗ Branch 116 not taken.
✓ Branch 118 taken 25 times.
✗ Branch 119 not taken.
✓ Branch 121 taken 25 times.
✗ Branch 122 not taken.
✓ Branch 124 taken 25 times.
✗ Branch 125 not taken.
✓ Branch 127 taken 25 times.
✗ Branch 128 not taken.
✓ Branch 130 taken 25 times.
✗ Branch 131 not taken.
✓ Branch 133 taken 25 times.
✗ Branch 134 not taken.
✗ Branch 136 not taken.
✗ Branch 137 not taken.
✗ Branch 139 not taken.
✗ Branch 140 not taken.
✗ Branch 142 not taken.
✗ Branch 143 not taken.
✗ Branch 145 not taken.
✗ Branch 146 not taken.
✗ Branch 148 not taken.
✗ Branch 149 not taken.
✗ Branch 151 not taken.
✗ Branch 152 not taken.
✗ Branch 154 not taken.
✗ Branch 155 not taken.
✗ Branch 157 not taken.
✗ Branch 158 not taken.
✗ Branch 160 not taken.
✗ Branch 161 not taken.
✗ Branch 163 not taken.
✗ Branch 164 not taken.
✗ Branch 166 not taken.
✗ Branch 167 not taken.
✗ Branch 169 not taken.
✗ Branch 170 not taken.
✓ Branch 172 taken 25 times.
✗ Branch 173 not taken.
✓ Branch 175 taken 25 times.
✗ Branch 176 not taken.
✓ Branch 178 taken 25 times.
✗ Branch 179 not taken.
✓ Branch 181 taken 1 times.
✗ Branch 182 not taken.
✓ Branch 184 taken 25 times.
✗ Branch 185 not taken.
✓ Branch 187 taken 25 times.
✗ Branch 188 not taken.
✓ Branch 190 taken 25 times.
✗ Branch 191 not taken.
✓ Branch 193 taken 1 times.
✗ Branch 194 not taken.
✓ Branch 196 taken 25 times.
✗ Branch 197 not taken.
✓ Branch 199 taken 25 times.
✗ Branch 200 not taken.
✓ Branch 202 taken 25 times.
✗ Branch 203 not taken.
✓ Branch 205 taken 1 times.
✗ Branch 206 not taken.
✓ Branch 208 taken 25 times.
✗ Branch 209 not taken.
✓ Branch 211 taken 25 times.
✗ Branch 212 not taken.
✓ Branch 214 taken 25 times.
✗ Branch 215 not taken.
✓ Branch 217 taken 1 times.
✗ Branch 218 not taken.
✓ Branch 220 taken 25 times.
✗ Branch 221 not taken.
✓ Branch 223 taken 25 times.
✗ Branch 224 not taken.
✓ Branch 226 taken 25 times.
✗ Branch 227 not taken.
✓ Branch 229 taken 1 times.
✗ Branch 230 not taken.
✓ Branch 232 taken 25 times.
✗ Branch 233 not taken.
✓ Branch 235 taken 25 times.
✗ Branch 236 not taken.
✓ Branch 238 taken 25 times.
✗ Branch 239 not taken.
✓ Branch 241 taken 1 times.
✗ Branch 242 not taken.
✓ Branch 244 taken 25 times.
✗ Branch 245 not taken.
✓ Branch 247 taken 25 times.
✗ Branch 248 not taken.
✓ Branch 250 taken 25 times.
✗ Branch 251 not taken.
✓ Branch 253 taken 1 times.
✗ Branch 254 not taken.
✓ Branch 256 taken 25 times.
✗ Branch 257 not taken.
✓ Branch 259 taken 25 times.
✗ Branch 260 not taken.
✓ Branch 262 taken 25 times.
✗ Branch 263 not taken.
✓ Branch 265 taken 1 times.
✗ Branch 266 not taken.
✓ Branch 268 taken 25 times.
✗ Branch 269 not taken.
✓ Branch 271 taken 25 times.
✗ Branch 272 not taken.
✓ Branch 274 taken 25 times.
✗ Branch 275 not taken.
✓ Branch 277 taken 1 times.
✗ Branch 278 not taken.
✗ Branch 280 not taken.
✗ Branch 281 not taken.
✓ Branch 283 taken 25 times.
✗ Branch 284 not taken.
✓ Branch 286 taken 25 times.
✗ Branch 287 not taken.
✓ Branch 289 taken 25 times.
✗ Branch 290 not taken.
✓ Branch 292 taken 1 times.
✗ Branch 293 not taken.
✗ Branch 295 not taken.
✗ Branch 296 not taken.
✓ Branch 298 taken 25 times.
✗ Branch 299 not taken.
✓ Branch 301 taken 25 times.
✗ Branch 302 not taken.
✓ Branch 304 taken 25 times.
✗ Branch 305 not taken.
✓ Branch 307 taken 1 times.
✗ Branch 308 not taken.
✗ Branch 310 not taken.
✗ Branch 311 not taken.
✓ Branch 313 taken 25 times.
✗ Branch 314 not taken.
✓ Branch 316 taken 25 times.
✗ Branch 317 not taken.
✓ Branch 319 taken 25 times.
✗ Branch 320 not taken.
✓ Branch 322 taken 1 times.
✗ Branch 323 not taken.
✗ Branch 325 not taken.
✗ Branch 326 not taken.
✓ Branch 328 taken 25 times.
✗ Branch 329 not taken.
✓ Branch 331 taken 25 times.
✗ Branch 332 not taken.
✓ Branch 334 taken 25 times.
✗ Branch 335 not taken.
✓ Branch 337 taken 1 times.
✗ Branch 338 not taken.
✓ Branch 340 taken 25 times.
✗ Branch 341 not taken.
✓ Branch 343 taken 25 times.
✗ Branch 344 not taken.
✓ Branch 346 taken 25 times.
✗ Branch 347 not taken.
✓ Branch 349 taken 1 times.
✗ Branch 350 not taken.
✓ Branch 352 taken 25 times.
✗ Branch 353 not taken.
✓ Branch 355 taken 25 times.
✗ Branch 356 not taken.
✓ Branch 358 taken 25 times.
✗ Branch 359 not taken.
✓ Branch 361 taken 1 times.
✗ Branch 362 not taken.
✓ Branch 364 taken 25 times.
✗ Branch 365 not taken.
✓ Branch 367 taken 25 times.
✗ Branch 368 not taken.
✓ Branch 370 taken 25 times.
✗ Branch 371 not taken.
✓ Branch 373 taken 1 times.
✗ Branch 374 not taken.
✓ Branch 376 taken 25 times.
✗ Branch 377 not taken.
✓ Branch 379 taken 25 times.
✗ Branch 380 not taken.
✓ Branch 382 taken 25 times.
✗ Branch 383 not taken.
✓ Branch 385 taken 1 times.
✗ Branch 386 not taken.
✗ Branch 388 not taken.
✗ Branch 389 not taken.
✓ Branch 391 taken 25 times.
✗ Branch 392 not taken.
✓ Branch 394 taken 25 times.
✗ Branch 395 not taken.
✓ Branch 397 taken 25 times.
✗ Branch 398 not taken.
✓ Branch 400 taken 1 times.
✗ Branch 401 not taken.
✗ Branch 403 not taken.
✗ Branch 404 not taken.
✓ Branch 406 taken 25 times.
✗ Branch 407 not taken.
✓ Branch 409 taken 25 times.
✗ Branch 410 not taken.
✓ Branch 412 taken 25 times.
✗ Branch 413 not taken.
✓ Branch 415 taken 1 times.
✗ Branch 416 not taken.
✗ Branch 418 not taken.
✗ Branch 419 not taken.
✓ Branch 421 taken 25 times.
✗ Branch 422 not taken.
✓ Branch 424 taken 25 times.
✗ Branch 425 not taken.
✓ Branch 427 taken 25 times.
✗ Branch 428 not taken.
✓ Branch 430 taken 1 times.
✗ Branch 431 not taken.
✗ Branch 433 not taken.
✗ Branch 434 not taken.
✗ Branch 436 not taken.
✗ Branch 437 not taken.
✗ Branch 439 not taken.
✗ Branch 440 not taken.
✗ Branch 442 not taken.
✗ Branch 443 not taken.
✗ Branch 445 not taken.
✗ Branch 446 not taken.
✓ Branch 448 taken 50 times.
✗ Branch 449 not taken.
✓ Branch 451 taken 25 times.
✗ Branch 452 not taken.
✓ Branch 454 taken 50 times.
✗ Branch 455 not taken.
✓ Branch 457 taken 25 times.
✗ Branch 458 not taken.
✓ Branch 460 taken 50 times.
✗ Branch 461 not taken.
✓ Branch 463 taken 25 times.
✗ Branch 464 not taken.
✓ Branch 466 taken 50 times.
✗ Branch 467 not taken.
✓ Branch 469 taken 25 times.
✗ Branch 470 not taken.
✓ Branch 472 taken 50 times.
✗ Branch 473 not taken.
✓ Branch 475 taken 25 times.
✗ Branch 476 not taken.
✓ Branch 478 taken 50 times.
✗ Branch 479 not taken.
✓ Branch 481 taken 25 times.
✗ Branch 482 not taken.
✓ Branch 484 taken 50 times.
✗ Branch 485 not taken.
✓ Branch 487 taken 25 times.
✗ Branch 488 not taken.
✓ Branch 490 taken 50 times.
✗ Branch 491 not taken.
✓ Branch 493 taken 25 times.
✗ Branch 494 not taken.
✓ Branch 496 taken 50 times.
✗ Branch 497 not taken.
✓ Branch 499 taken 25 times.
✗ Branch 500 not taken.
✓ Branch 502 taken 50 times.
✗ Branch 503 not taken.
✓ Branch 505 taken 25 times.
✗ Branch 506 not taken.
✓ Branch 508 taken 50 times.
✗ Branch 509 not taken.
✓ Branch 511 taken 25 times.
✗ Branch 512 not taken.
✓ Branch 514 taken 50 times.
✗ Branch 515 not taken.
✓ Branch 517 taken 25 times.
✗ Branch 518 not taken.
✓ Branch 520 taken 50 times.
✗ Branch 521 not taken.
✓ Branch 523 taken 25 times.
✗ Branch 524 not taken.
✓ Branch 526 taken 25 times.
✗ Branch 527 not taken.
✓ Branch 529 taken 50 times.
✗ Branch 530 not taken.
✓ Branch 532 taken 25 times.
✗ Branch 533 not taken.
✓ Branch 535 taken 25 times.
✗ Branch 536 not taken.
✓ Branch 538 taken 50 times.
✗ Branch 539 not taken.
✓ Branch 541 taken 25 times.
✗ Branch 542 not taken.
✓ Branch 544 taken 25 times.
✗ Branch 545 not taken.
✓ Branch 547 taken 50 times.
✗ Branch 548 not taken.
✓ Branch 550 taken 25 times.
✗ Branch 551 not taken.
✓ Branch 553 taken 25 times.
✗ Branch 554 not taken.
✓ Branch 556 taken 50 times.
✗ Branch 557 not taken.
✓ Branch 559 taken 50 times.
✗ Branch 560 not taken.
✓ Branch 562 taken 50 times.
✗ Branch 563 not taken.
✓ Branch 565 taken 50 times.
✗ Branch 566 not taken.
✓ Branch 568 taken 50 times.
✗ Branch 569 not taken.
✓ Branch 571 taken 50 times.
✗ Branch 572 not taken.
✓ Branch 574 taken 50 times.
✗ Branch 575 not taken.
✓ Branch 577 taken 50 times.
✗ Branch 578 not taken.
3745 { this->bindElement_(element); }
196
197 //! Returns true if bind/bindElement has already been called
198 bool isBound() const
199 { return static_cast<bool>(element_); }
200
201 //! The bound element
202 const Element& element() const
203
32/32
✓ Branch 0 taken 5 times.
✓ Branch 1 taken 15 times.
✓ Branch 2 taken 5 times.
✓ Branch 3 taken 15 times.
✓ Branch 4 taken 5 times.
✓ Branch 5 taken 15 times.
✓ Branch 6 taken 5 times.
✓ Branch 7 taken 15 times.
✓ Branch 8 taken 5 times.
✓ Branch 9 taken 15 times.
✓ Branch 10 taken 5 times.
✓ Branch 11 taken 15 times.
✓ Branch 12 taken 5 times.
✓ Branch 13 taken 15 times.
✓ Branch 14 taken 5 times.
✓ Branch 15 taken 15 times.
✓ Branch 16 taken 5 times.
✓ Branch 17 taken 15 times.
✓ Branch 18 taken 5 times.
✓ Branch 19 taken 15 times.
✓ Branch 20 taken 5 times.
✓ Branch 21 taken 15 times.
✓ Branch 22 taken 5 times.
✓ Branch 23 taken 15 times.
✓ Branch 24 taken 5 times.
✓ Branch 25 taken 15 times.
✓ Branch 26 taken 5 times.
✓ Branch 27 taken 15 times.
✓ Branch 28 taken 5 times.
✓ Branch 29 taken 15 times.
✓ Branch 30 taken 5 times.
✓ Branch 31 taken 15 times.
400 { return *element_; }
204
205 //! The grid finite volume geometry we are a restriction of
206 18625 const GridGeometry& gridGeometry() const
207 4800 { return *gridGeometryPtr_; }
208
209 //! Returns whether one of the geometry's scvfs lies on a boundary
210 1100 bool hasBoundaryScvf() const
211
88/88
✓ Branch 0 taken 16 times.
✓ Branch 1 taken 9 times.
✓ Branch 2 taken 16 times.
✓ Branch 3 taken 9 times.
✓ Branch 4 taken 16 times.
✓ Branch 5 taken 9 times.
✓ Branch 6 taken 16 times.
✓ Branch 7 taken 9 times.
✓ Branch 8 taken 16 times.
✓ Branch 9 taken 9 times.
✓ Branch 10 taken 16 times.
✓ Branch 11 taken 9 times.
✓ Branch 12 taken 16 times.
✓ Branch 13 taken 9 times.
✓ Branch 14 taken 16 times.
✓ Branch 15 taken 9 times.
✓ Branch 16 taken 16 times.
✓ Branch 17 taken 9 times.
✓ Branch 18 taken 16 times.
✓ Branch 19 taken 9 times.
✓ Branch 20 taken 16 times.
✓ Branch 21 taken 9 times.
✓ Branch 22 taken 16 times.
✓ Branch 23 taken 9 times.
✓ Branch 24 taken 16 times.
✓ Branch 25 taken 9 times.
✓ Branch 26 taken 16 times.
✓ Branch 27 taken 9 times.
✓ Branch 28 taken 16 times.
✓ Branch 29 taken 9 times.
✓ Branch 30 taken 16 times.
✓ Branch 31 taken 9 times.
✓ Branch 32 taken 16 times.
✓ Branch 33 taken 9 times.
✓ Branch 34 taken 16 times.
✓ Branch 35 taken 9 times.
✓ Branch 36 taken 16 times.
✓ Branch 37 taken 9 times.
✓ Branch 38 taken 16 times.
✓ Branch 39 taken 9 times.
✓ Branch 40 taken 16 times.
✓ Branch 41 taken 9 times.
✓ Branch 42 taken 16 times.
✓ Branch 43 taken 9 times.
✓ Branch 44 taken 16 times.
✓ Branch 45 taken 9 times.
✓ Branch 46 taken 16 times.
✓ Branch 47 taken 9 times.
✓ Branch 48 taken 9 times.
✓ Branch 49 taken 16 times.
✓ Branch 50 taken 9 times.
✓ Branch 51 taken 16 times.
✓ Branch 52 taken 9 times.
✓ Branch 53 taken 16 times.
✓ Branch 54 taken 9 times.
✓ Branch 55 taken 16 times.
✓ Branch 56 taken 9 times.
✓ Branch 57 taken 16 times.
✓ Branch 58 taken 9 times.
✓ Branch 59 taken 16 times.
✓ Branch 60 taken 9 times.
✓ Branch 61 taken 16 times.
✓ Branch 62 taken 9 times.
✓ Branch 63 taken 16 times.
✓ Branch 64 taken 9 times.
✓ Branch 65 taken 16 times.
✓ Branch 66 taken 9 times.
✓ Branch 67 taken 16 times.
✓ Branch 68 taken 9 times.
✓ Branch 69 taken 16 times.
✓ Branch 70 taken 9 times.
✓ Branch 71 taken 16 times.
✓ Branch 72 taken 9 times.
✓ Branch 73 taken 16 times.
✓ Branch 74 taken 9 times.
✓ Branch 75 taken 16 times.
✓ Branch 76 taken 9 times.
✓ Branch 77 taken 16 times.
✓ Branch 78 taken 9 times.
✓ Branch 79 taken 16 times.
✓ Branch 80 taken 9 times.
✓ Branch 81 taken 16 times.
✓ Branch 82 taken 9 times.
✓ Branch 83 taken 16 times.
✓ Branch 84 taken 9 times.
✓ Branch 85 taken 16 times.
✓ Branch 86 taken 9 times.
✓ Branch 87 taken 16 times.
1100 { return hasBoundaryScvf_; }
212
213 //! Create the geometry of a given sub control volume
214 typename SubControlVolume::Traits::Geometry geometry(const SubControlVolume& scv) const
215 { return gridGeometryPtr_->element(scv.dofIndex()).geometry(); }
216
217 //! Create the geometry of a given sub control volume face
218
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 100 times.
100 typename SubControlVolumeFace::Traits::Geometry geometry(const SubControlVolumeFace& scvf) const
219 {
220 100 const auto insideElementIndex = scvf.insideScvIdx();
221
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 100 times.
200 const auto elementGeometry = (insideElementIndex != scvIndices_[0]) ?
222 element_->geometry() :
223 100 gridGeometryPtr_->element(insideElementIndex).geometry();
224 100 const auto center = elementGeometry.center();
225 100 const auto normalAxis = Dumux::normalAxis(scvf.unitOuterNormal());
226
227 100 auto lowerLeft = elementGeometry.corner(0);
228 200 auto upperRight = elementGeometry.corner(elementGeometry.corners()-1);
229
230 // shift corners to scvf plane and halve lateral faces
231 100 lowerLeft[normalAxis] = center[normalAxis];
232 100 upperRight[normalAxis] = center[normalAxis];
233
234 100 auto inPlaneAxes = std::move(std::bitset<SubControlVolumeFace::Traits::dimWorld>{}.set());
235 100 inPlaneAxes.set(normalAxis, false);
236
237 100 return {lowerLeft, upperRight, inPlaneAxes};
238 }
239
240 private:
241 //! Binding of an element preparing the geometries only inside the element
242 4945 void bindElement_(const Element& element)
243 {
244 4945 clear_();
245
2/2
✓ Branch 0 taken 4732 times.
✓ Branch 1 taken 213 times.
4945 element_ = element;
246 4945 scvfs_.reserve(element.subEntities(1));
247 4945 scvfIndices_.reserve(element.subEntities(1));
248 4945 makeElementGeometries_();
249 4945 }
250
251 //! Binding of an element preparing the geometries of the whole stencil
252 //! called by the local jacobian to prepare element assembly
253 1200 void bind_(const Element& element)
254 {
255 1200 bindElement_(element);
256
257 1200 neighborScvs_.reserve(element.subEntities(1));
258 1200 neighborScvfIndices_.reserve(element.subEntities(1));
259 1200 neighborScvfs_.reserve(element.subEntities(1));
260
261
1/2
✓ Branch 1 taken 1200 times.
✗ Branch 2 not taken.
1200 std::vector<GridIndexType> handledNeighbors;
262
1/2
✓ Branch 1 taken 1200 times.
✗ Branch 2 not taken.
1200 handledNeighbors.reserve(element.subEntities(1));
263
4/4
✓ Branch 1 taken 1200 times.
✓ Branch 2 taken 4800 times.
✓ Branch 4 taken 4320 times.
✓ Branch 5 taken 480 times.
6000 for (const auto& intersection : intersections(gridGeometry().gridView(), element))
264 {
265 8640 if (intersection.neighbor())
266 {
267 3840 const auto outside = intersection.outside();
268
1/2
✓ Branch 1 taken 3840 times.
✗ Branch 2 not taken.
3840 const auto outsideIdx = gridGeometry().elementMapper().index(outside);
269
270 // make outside geometries only if not done yet (could happen on non-conforming grids)
271
1/2
✓ Branch 0 taken 3840 times.
✗ Branch 1 not taken.
3840 if ( std::find(handledNeighbors.begin(), handledNeighbors.end(), outsideIdx) == handledNeighbors.end() )
272 {
273
1/2
✓ Branch 1 taken 3840 times.
✗ Branch 2 not taken.
3840 makeNeighborGeometries_(outside, outsideIdx);
274
1/2
✓ Branch 1 taken 3840 times.
✗ Branch 2 not taken.
3840 handledNeighbors.push_back(outsideIdx);
275 }
276 }
277 }
278 1200 }
279
280 //! create scvs and scvfs of the bound element
281 4945 void makeElementGeometries_()
282 {
283 4945 const auto& element = *element_;
284 4945 const auto eIdx = gridGeometry().elementMapper().index(element);
285 4945 scvs_[0] = SubControlVolume(element.geometry(), eIdx);
286 4945 scvIndices_[0] = eIdx;
287
288 4945 const auto& scvFaceIndices = gridGeometry().scvfIndicesOfScv(eIdx);
289 4945 const auto& neighborVolVarIndices = gridGeometry().neighborVolVarIndices(eIdx);
290
291 4945 typename GridGeometry::GeometryHelper geometryHelper(element, gridGeometry().gridView());
292
293 4945 int scvfCounter = 0;
294
2/2
✓ Branch 1 taken 4945 times.
✓ Branch 2 taken 19780 times.
24725 for (const auto& intersection : intersections(gridGeometry().gridView(), element))
295 {
296
2/2
✓ Branch 0 taken 17770 times.
✓ Branch 1 taken 2010 times.
19780 const auto& scvfNeighborVolVarIndex = neighborVolVarIndices[scvfCounter];
297
298
1/2
✓ Branch 0 taken 3980 times.
✗ Branch 1 not taken.
3980 if (intersection.neighbor() || intersection.boundary())
299 {
300 19780 geometryHelper.updateLocalFace(gridGeometry().intersectionMapper(), intersection);
301
1/2
✓ Branch 1 taken 19780 times.
✗ Branch 2 not taken.
19780 std::vector<GridIndexType> scvIndices{eIdx, scvfNeighborVolVarIndex};
302 39560 scvfs_.emplace_back(intersection,
303
1/2
✓ Branch 1 taken 19780 times.
✗ Branch 2 not taken.
19780 intersection.geometry(),
304 19780 scvFaceIndices[scvfCounter],
305 scvIndices,
306 geometryHelper);
307
1/2
✓ Branch 1 taken 19780 times.
✗ Branch 2 not taken.
19780 scvfIndices_.emplace_back(scvFaceIndices[scvfCounter]);
308
2/2
✓ Branch 0 taken 3980 times.
✓ Branch 1 taken 15800 times.
19780 scvfCounter++;
309
310
2/2
✓ Branch 0 taken 3980 times.
✓ Branch 1 taken 15800 times.
19780 if (intersection.boundary())
311 3980 hasBoundaryScvf_ = true;
312 19780 }
313 }
314 4945 }
315
316 //! create the necessary scvs and scvfs of the neighbor elements to the bound elements
317 3840 void makeNeighborGeometries_(const Element& element, const GridIndexType eIdx)
318 {
319 // using ScvfGridIndexStorage = typename SubControlVolumeFace::Traits::GridIndexStorage;
320
321 // create the neighbor scv
322 3840 neighborScvs_.emplace_back(element.geometry(), eIdx);
323 3840 neighborScvIndices_.push_back(eIdx);
324
325 3840 const auto& scvFaceIndices = gridGeometry().scvfIndicesOfScv(eIdx);
326 3840 const auto& neighborVolVarIndices = gridGeometry().neighborVolVarIndices(eIdx);
327
328 3840 typename GridGeometry::GeometryHelper geometryHelper(element, gridGeometry().gridView());
329
330 3840 int scvfCounter = 0;
331
2/2
✓ Branch 1 taken 3840 times.
✓ Branch 2 taken 15360 times.
19200 for (const auto& intersection : intersections(gridGeometry().gridView(), element))
332 {
333 15360 const auto& scvfNeighborVolVarIndex = neighborVolVarIndices[scvfCounter];
334
2/2
✓ Branch 1 taken 14112 times.
✓ Branch 2 taken 1248 times.
30720 geometryHelper.updateLocalFace(gridGeometry().intersectionMapper(), intersection);
335
336
1/2
✓ Branch 0 taken 2496 times.
✗ Branch 1 not taken.
2496 if (intersection.neighbor())
337 {
338 // only create subcontrol faces where the outside element is the bound element
339
1/2
✓ Branch 0 taken 12864 times.
✗ Branch 1 not taken.
12864 if (intersection.outside() == *element_)
340 {
341 3840 std::vector<GridIndexType> scvIndices{eIdx, scvfNeighborVolVarIndex};
342 7680 neighborScvfs_.emplace_back(intersection,
343
1/2
✓ Branch 1 taken 3840 times.
✗ Branch 2 not taken.
3840 intersection.geometry(),
344 3840 scvFaceIndices[scvfCounter],
345 scvIndices,
346 geometryHelper);
347
348
1/2
✓ Branch 1 taken 3840 times.
✗ Branch 2 not taken.
3840 neighborScvfIndices_.push_back(scvFaceIndices[scvfCounter]);
349 3840 }
350 12864 scvfCounter++;
351 }
352
1/2
✓ Branch 0 taken 2496 times.
✗ Branch 1 not taken.
2496 else if (intersection.boundary())
353 2496 scvfCounter++;
354 }
355 3840 }
356
357
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 1920 times.
1920 const LocalIndexType findLocalIndex_(const GridIndexType idx,
358 const std::vector<GridIndexType>& indices) const
359 {
360
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 1920 times.
1920 auto it = std::find(indices.begin(), indices.end(), idx);
361
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 1920 times.
1920 assert(it != indices.end() && "Could not find the scv/scvf! Make sure to properly bind this class!");
362 1920 return std::distance(indices.begin(), it);
363 }
364
365 //! Clear all local data
366 4945 void clear_()
367 {
368
2/2
✓ Branch 0 taken 4732 times.
✓ Branch 1 taken 213 times.
4945 scvfIndices_.clear();
369
2/2
✓ Branch 0 taken 4732 times.
✓ Branch 1 taken 213 times.
4945 scvfs_.clear();
370
371
2/2
✓ Branch 0 taken 1152 times.
✓ Branch 1 taken 3793 times.
4945 neighborScvIndices_.clear();
372
2/2
✓ Branch 0 taken 1152 times.
✓ Branch 1 taken 3793 times.
4945 neighborScvfIndices_.clear();
373
2/2
✓ Branch 0 taken 1152 times.
✓ Branch 1 taken 3793 times.
4945 neighborScvs_.clear();
374
2/2
✓ Branch 0 taken 1152 times.
✓ Branch 1 taken 3793 times.
4945 neighborScvfs_.clear();
375
376 4945 hasBoundaryScvf_ = false;
377 4945 }
378
379 std::optional<Element> element_; //!< the element to which this fvgeometry is bound
380 const GridGeometry* gridGeometryPtr_; //!< the grid fvgeometry
381
382 // local storage after binding an element
383 std::array<GridIndexType, 1> scvIndices_;
384 std::array<SubControlVolume, 1> scvs_;
385
386 std::vector<GridIndexType> scvfIndices_;
387 std::vector<SubControlVolumeFace> scvfs_;
388
389 std::vector<GridIndexType> neighborScvIndices_;
390 std::vector<SubControlVolume> neighborScvs_;
391
392 std::vector<GridIndexType> neighborScvfIndices_;
393 std::vector<SubControlVolumeFace> neighborScvfs_;
394
395 bool hasBoundaryScvf_ = false;
396 };
397
398
399 } // end namespace
400
401 #endif
402