Visual Computing Library
Loading...
Searching...
No Matches
quality.h
1/*****************************************************************************
2 * VCLib *
3 * Visual Computing Library *
4 * *
5 * Copyright(C) 2021-2025 *
6 * Visual Computing Lab *
7 * ISTI - Italian National Research Council *
8 * *
9 * All rights reserved. *
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the Mozilla Public License Version 2.0 as published *
13 * by the Mozilla Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 * This program is distributed in the hope that it will be useful, *
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
19 * Mozilla Public License Version 2.0 *
20 * (https://www.mozilla.org/en-US/MPL/2.0/) for more details. *
21 ****************************************************************************/
22
23#ifndef VCL_MESH_COMPONENTS_QUALITY_H
24#define VCL_MESH_COMPONENTS_QUALITY_H
25
26#include "bases/component.h"
27
28#include <vclib/concepts/mesh/components/quality.h>
29#include <vclib/io/serialization.h>
30
31namespace vcl::comp {
32
57template<typename Scalar, typename ParentElemType = void, bool OPT = false>
58class Quality :
59 public Component<
60 Quality<Scalar, ParentElemType, OPT>,
61 CompId::QUALITY,
62 Scalar,
63 ParentElemType,
64 !std::is_same_v<ParentElemType, void>,
65 OPT>
66{
67 using Base = Component<
69 CompId::QUALITY,
70 Scalar,
72 !std::is_same_v<ParentElemType, void>,
73 OPT>;
74
75public:
79 using QualityType = Scalar;
80
81 /* Constructors */
82
86 Quality() = default;
87
88 /* Member functions */
89
94 const QualityType& quality() const { return Base::data(); }
95
100 QualityType& quality() { return Base::data(); }
101
102protected:
103 // Component interface functions
104 template<typename Element>
105 void importFrom(const Element& e, bool = true)
106 {
107 if constexpr (HasQuality<Element>) {
108 if (isQualityAvailableOn(e)) {
109 quality() = e.quality();
110 }
111 }
112 }
113
114 void serialize(std::ostream& os) const { vcl::serialize(os, quality()); }
115
116 void deserialize(std::istream& is) { vcl::deserialize(is, quality()); }
117};
118
119/* Detector function to check if a class has Quality available */
120
133bool isQualityAvailableOn(const ElementOrMeshConcept auto& element)
134{
135 return isComponentAvailableOn<CompId::QUALITY>(element);
136}
137
138/* Specialization Aliases */
139
152template<typename ElementType = void, bool OPT = false>
154
167template<typename ElementType = void, bool OPT = false>
169
170} // namespace vcl::comp
171
172#endif // VCL_MESH_COMPONENTS_QUALITY_H
The Element class.
Definition element.h:57
A class representing a line segment in n-dimensional space. The class is parameterized by a PointConc...
Definition segment.h:43
The Quality class represents a component that stores the quality of a mesh element,...
Definition quality.h:66
const QualityType & quality() const
Returns a const reference of the quality of the element.
Definition quality.h:94
Scalar QualityType
Exposes the scalar used as Quality type.
Definition quality.h:79
Quality()=default
Initilizes the Quality value to 0.
QualityType & quality()
Returns a reference of the quality of the element.
Definition quality.h:100
HasQuality concept is satisfied only if a Element class provides the types and member functions speci...
Definition quality.h:47