55 std::array<SpatialDomains::PointGeom *, 8> v,
56 std::array<SpatialDomains::SegGeomUniquePtr, 12> &segVec,
57 std::array<SpatialDomains::QuadGeomUniquePtr, 6> &faceVec)
59 std::array<std::array<int, 2>, 12> edgeVerts = {{{{0, 1}},
71 std::array<std::array<int, 4>, 6> faceEdges = {{{{0, 1, 2, 3}},
79 for (
int i = 0; i < 12; ++i)
81 segVec[i] =
CreateSegGeom(i, v[edgeVerts[i][0]], v[edgeVerts[i][1]]);
85 std::array<SpatialDomains::QuadGeom *, 6> faces;
86 for (
int i = 0; i < 6; ++i)
88 std::array<SpatialDomains::SegGeom *, 4> face;
89 for (
int j = 0; j < 4; ++j)
91 face[j] = segVec[faceEdges[i][j]].get();
95 faces[i] = faceVec[i].get();
122 std::array<SpatialDomains::PointGeom *, 8> v = {
123 v0.get(), v1.get(), v2.get(), v3.get(),
124 v4.get(), v5.get(), v6.get(), v7.get()};
125 std::array<SpatialDomains::SegGeomUniquePtr, 12> segVec;
126 std::array<SpatialDomains::QuadGeomUniquePtr, 6> faceVec;
133 unsigned int numQuadPoints = 6;
141 basisKeyDir1, basisKeyDir1, basisKeyDir1, hexGeom.get());
146 hexExp->GetCoords(c0, c1, c2);
147 std::shared_ptr<StdRegions::StdHexExp> stdHex =
148 std::dynamic_pointer_cast<StdRegions::StdHexExp>(hexExp);
149 stdHex->GetCoords(c0, c1, c2);
150 double epsilon = 1.0e-8;
151 BOOST_CHECK_CLOSE(c0[0], -1.0, epsilon);
152 BOOST_CHECK_CLOSE(c0[1], -0.76505532392946474, epsilon);
153 BOOST_CHECK_CLOSE(c0[2], -0.28523151648064510, epsilon);
154 BOOST_CHECK_CLOSE(c0[3], 0.28523151648064510, epsilon);
155 BOOST_CHECK_CLOSE(c0[4], 0.76505532392946474, epsilon);
156 BOOST_CHECK_CLOSE(c0[5], 1.0, epsilon);
178 std::array<SpatialDomains::PointGeom *, 8> v = {
179 v0.get(), v1.get(), v2.get(), v3.get(),
180 v4.get(), v5.get(), v6.get(), v7.get()};
181 std::array<SpatialDomains::SegGeomUniquePtr, 12> segVec;
182 std::array<SpatialDomains::QuadGeomUniquePtr, 6> faceVec;
189 unsigned int numQuadPoints = 6;
197 basisKeyDir1, basisKeyDir1, basisKeyDir1, hexGeom.get());
202 hexExp->GetCoords(c0, c1, c2);
204 double epsilon = 1.0e-8;
205 BOOST_CHECK_EQUAL(c0[0], 0.0);
206 BOOST_CHECK_CLOSE(c0[1], .05873616902, epsilon);
207 BOOST_CHECK_CLOSE(c0[2], .17869212088, epsilon);
208 BOOST_CHECK_CLOSE(c0[3], .32130787912, epsilon);
209 BOOST_CHECK_CLOSE(c0[4], .44126383098, epsilon);
210 BOOST_CHECK_CLOSE(c0[5], .5, epsilon);
222 unsigned int numQuadPoints = 1;
223 unsigned int numModes = 1;
234 pointExp->GetCoords(c0, c1, c2);
236 std::shared_ptr<StdRegions::StdPointExp> stdPoint =
237 std::dynamic_pointer_cast<StdRegions::StdPointExp>(pointExp);
245 stdPoint->GetCoords(c0_arr, c1_arr, c2_arr);
247 double epsilon = 1.0e-8;
248 BOOST_CHECK_CLOSE(c0, -1.0, epsilon);
249 BOOST_CHECK_CLOSE(c0_arr[0], -1.0, epsilon);
252 auto gtype = pointExp->GetMetricInfo()->GetGtype();
256 auto jac = pointExp->GetMetricInfo()->GetJac(pointExp->GetPointsKeys());
257 BOOST_CHECK_CLOSE(jac[0], 1.0, epsilon);