GCC Code Coverage Report


Directory: ./
File: src/distance/convex_plane.cpp
Date: 2025-05-02 10:16:21
Exec Total Coverage
Lines: 1 2 50.0%
Branches: 1 4 25.0%

Line Branch Exec Source
1 /*
2 * Software License Agreement (BSD License)
3 *
4 * Copyright (c) 2024, INRIA
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 *
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * * Redistributions in binary form must reproduce the above
14 * copyright notice, this list of conditions and the following
15 * disclaimer in the documentation and/or other materials provided
16 * with the distribution.
17 * * Neither the name of Open Source Robotics Foundation nor the names of its
18 * contributors may be used to endorse or promote products derived
19 * from this software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
24 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
25 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
26 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
27 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
28 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
31 * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
32 * POSSIBILITY OF SUCH DAMAGE.
33 */
34
35 /** \author Louis Montaut */
36
37 #include "coal/shape/geometric_shapes.h"
38
39 #include "coal/internal/shape_shape_func.h"
40 #include "../narrowphase/details.h"
41
42 #include "coal/tracy.hh"
43
44 namespace coal {
45
46 namespace internal {
47
48 #define ConvexPlaneShapeShapeDistance(ConvexBaseType) \
49 template <> \
50 Scalar ShapeShapeDistance<ConvexBaseType, Plane>( \
51 const CollisionGeometry* o1, const Transform3s& tf1, \
52 const CollisionGeometry* o2, const Transform3s& tf2, const GJKSolver*, \
53 const bool, Vec3s& p1, Vec3s& p2, Vec3s& normal) { \
54 COAL_TRACY_ZONE_SCOPED_N( \
55 "coal::internal::ShapeShapeDistance<ConvexBase, Plane>"); \
56 const ConvexBaseType& s1 = static_cast<const ConvexBaseType&>(*o1); \
57 const Plane& s2 = static_cast<const Plane&>(*o2); \
58 const Scalar distance = \
59 details::planeDistance(s2, tf2, s1, tf1, p2, p1, normal); \
60 normal = -normal; \
61 return distance; \
62 } \
63 \
64 template <> \
65 Scalar ShapeShapeDistance<Plane, ConvexBaseType>( \
66 const CollisionGeometry* o1, const Transform3s& tf1, \
67 const CollisionGeometry* o2, const Transform3s& tf2, const GJKSolver*, \
68 const bool, Vec3s& p1, Vec3s& p2, Vec3s& normal) { \
69 COAL_TRACY_ZONE_SCOPED_N( \
70 "coal::internal::ShapeShapeDistance<Plane, ConvexBase>"); \
71 const Plane& s1 = static_cast<const Plane&>(*o1); \
72 const ConvexBaseType& s2 = static_cast<const ConvexBaseType&>(*o2); \
73 return details::planeDistance(s1, tf1, s2, tf2, p1, p2, normal); \
74 }
75
76 ConvexPlaneShapeShapeDistance(ConvexBase16);
77
1/2
✓ Branch 3 taken 32 times.
✗ Branch 4 not taken.
64 ConvexPlaneShapeShapeDistance(ConvexBase32);
78
79 } // namespace internal
80
81 } // namespace coal
82