mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-25 09:41:11 -06:00
Merged branch 'dev_native' into lm_sla_supports_auto
Added igl library files
This commit is contained in:
commit
7681d00ee5
2865 changed files with 142806 additions and 22325 deletions
74
src/igl/volume.h
Normal file
74
src/igl/volume.h
Normal file
|
|
@ -0,0 +1,74 @@
|
|||
// This file is part of libigl, a simple c++ geometry processing library.
|
||||
//
|
||||
// Copyright (C) 2014 Alec Jacobson <alecjacobson@gmail.com>
|
||||
//
|
||||
// This Source Code Form is subject to the terms of the Mozilla Public License
|
||||
// v. 2.0. If a copy of the MPL was not distributed with this file, You can
|
||||
// obtain one at http://mozilla.org/MPL/2.0/.
|
||||
#ifndef IGL_VOLUME_H
|
||||
#define IGL_VOLUME_H
|
||||
#include "igl_inline.h"
|
||||
#include <Eigen/Core>
|
||||
namespace igl
|
||||
{
|
||||
// VOLUME Compute volume for all tets of a given tet mesh
|
||||
// (V,T)
|
||||
//
|
||||
// vol = volume(V,T)
|
||||
//
|
||||
// Inputs:
|
||||
// V #V by dim list of vertex positions
|
||||
// T #V by 4 list of tet indices
|
||||
// Outputs:
|
||||
// vol #T list of dihedral angles (in radians)
|
||||
//
|
||||
template <
|
||||
typename DerivedV,
|
||||
typename DerivedT,
|
||||
typename Derivedvol>
|
||||
IGL_INLINE void volume(
|
||||
const Eigen::MatrixBase<DerivedV>& V,
|
||||
const Eigen::MatrixBase<DerivedT>& T,
|
||||
Eigen::PlainObjectBase<Derivedvol>& vol);
|
||||
template <
|
||||
typename DerivedA,
|
||||
typename DerivedB,
|
||||
typename DerivedC,
|
||||
typename DerivedD,
|
||||
typename Derivedvol>
|
||||
IGL_INLINE void volume(
|
||||
const Eigen::MatrixBase<DerivedA> & A,
|
||||
const Eigen::MatrixBase<DerivedB> & B,
|
||||
const Eigen::MatrixBase<DerivedC> & C,
|
||||
const Eigen::MatrixBase<DerivedD> & D,
|
||||
Eigen::PlainObjectBase<Derivedvol> & vol);
|
||||
// Single tet
|
||||
template <
|
||||
typename VecA,
|
||||
typename VecB,
|
||||
typename VecC,
|
||||
typename VecD>
|
||||
IGL_INLINE typename VecA::Scalar volume_single(
|
||||
const VecA & a,
|
||||
const VecB & b,
|
||||
const VecC & c,
|
||||
const VecD & d);
|
||||
// Intrinsic version:
|
||||
//
|
||||
// Inputs:
|
||||
// L #V by 6 list of edge lengths (see edge_lengths)
|
||||
template <
|
||||
typename DerivedL,
|
||||
typename Derivedvol>
|
||||
IGL_INLINE void volume(
|
||||
const Eigen::MatrixBase<DerivedL>& L,
|
||||
Eigen::PlainObjectBase<Derivedvol>& vol);
|
||||
}
|
||||
|
||||
#ifndef IGL_STATIC_LIBRARY
|
||||
# include "volume.cpp"
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue