GCC Code Coverage Report


Directory: ./
File: src/distance/halfspace_plane.cpp
Date: 2025-04-01 09:23:31
Exec Total Coverage
Lines: 4 10 40.0%
Branches: 0 2 0.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 struct GJKSolver;
46
47 namespace internal {
48 template <>
49 20 Scalar ShapeShapeDistance<Halfspace, Plane>(
50 const CollisionGeometry* o1, const Transform3s& tf1,
51 const CollisionGeometry* o2, const Transform3s& tf2, const GJKSolver*,
52 const bool, Vec3s& p1, Vec3s& p2, Vec3s& normal) {
53 COAL_TRACY_ZONE_SCOPED_N(
54 "coal::internal::ShapeShapeDistance<Halfspace, Plane>");
55 20 const Halfspace& s1 = static_cast<const Halfspace&>(*o1);
56 20 const Plane& s2 = static_cast<const Plane&>(*o2);
57 20 return details::halfspacePlaneDistance(s1, tf1, s2, tf2, p1, p2, normal);
58 }
59
60 template <>
61 Scalar ShapeShapeDistance<Plane, Halfspace>(
62 const CollisionGeometry* o1, const Transform3s& tf1,
63 const CollisionGeometry* o2, const Transform3s& tf2, const GJKSolver*,
64 const bool, Vec3s& p1, Vec3s& p2, Vec3s& normal) {
65 COAL_TRACY_ZONE_SCOPED_N(
66 "coal::internal::ShapeShapeDistance<Plane, Halfspace>");
67 const Plane& s1 = static_cast<const Plane&>(*o1);
68 const Halfspace& s2 = static_cast<const Halfspace&>(*o2);
69 Scalar distance =
70 details::halfspacePlaneDistance(s2, tf2, s1, tf1, p2, p1, normal);
71 normal = -normal;
72 return distance;
73 }
74 } // namespace internal
75
76 } // namespace coal
77