libcarla/include/system/boost/qvm/detail/cofactor_impl.hpp

61 lines
1.7 KiB
C++
Raw Normal View History

2024-10-18 13:19:59 +08:00
#ifndef BOOST_QVM_DETAIL_COFACTOR_IMPL_HPP_INCLUDED
#define BOOST_QVM_DETAIL_COFACTOR_IMPL_HPP_INCLUDED
// Copyright 2008-2022 Emil Dotchevski and Reverge Studios, Inc.
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
#include <boost/qvm/detail/determinant_impl.hpp>
#include <boost/qvm/mat_traits.hpp>
#include <boost/qvm/static_assert.hpp>
namespace boost { namespace qvm {
namespace
qvm_detail
{
template <class A>
BOOST_QVM_CONSTEXPR BOOST_QVM_INLINE_OPERATIONS
typename deduce_mat<A>::type
cofactor_impl( A const & a )
{
BOOST_QVM_STATIC_ASSERT(mat_traits<A>::rows==mat_traits<A>::cols);
int const N=mat_traits<A>::rows;
typedef typename mat_traits<A>::scalar_type T;
T c[N-1][N-1];
typedef typename deduce_mat<A>::type R;
R b;
for( int j=0; j!=N; ++j )
{
for( int i=0; i!=N; ++i )
{
int i1=0;
for( int ii=0; ii!=N; ++ii )
{
if( ii==i )
continue;
int j1=0;
for( int jj=0; jj!=N; ++jj )
{
if( jj==j )
continue;
c[i1][j1] = mat_traits<A>::read_element_idx(ii,jj,a);
++j1;
}
++i1;
}
T det = determinant_impl(c);
if( (i+j)&1 )
det=-det;
write_mat_element_idx(i,j,b,det);
}
}
return b;
}
}
} }
#endif