51 libmesh_assert(!
_roots.size());
65 &den = eig_sol.
betas();
68 unsigned int nvals = (int)
_Bmat.rows();
71 for (
unsigned int i=0; i<nvals; i++) {
95 const unsigned int nvals = this->
n_roots();
96 libmesh_assert_equal_to(nvals, sol.
n_roots());
100 for (
unsigned int i=0; i<nvals-1; i++)
105 unsigned int max_val_root = nvals-1;
106 for (
unsigned int j=i; j<nvals; j++) {
116 if (abs(val) > max_val) {
137 libmesh_assert(this->
n_roots() > 0);
139 const unsigned int nvals = this->
n_roots();
140 unsigned int n_participation_vals =
142 libmesh_assert(nvals);
145 output <<
" Flutter Root " << std::endl;
149 << std::setw(5) <<
"#" 150 << std::setw(15) <<
"k_ref" 151 << std::setw(15) <<
"V_ref" 152 << std::setw(15) <<
"g" 153 << std::setw(15) <<
"omega" 154 << std::setw(15) <<
"Re" 155 << std::setw(15) <<
"Im" 156 << std::setw(3) <<
" | ";
159 for (
unsigned int i=0; i<n_participation_vals; i++)
161 << std::setw(2) <<
" " 162 << std::setw(5) <<
"Mode " 164 << std::setw(2) <<
" ";
167 for (
unsigned int i=0; i<nvals; i++)
169 << std::setw(10) <<
"| " 170 << std::setw(5) <<
"Mode " 172 << std::setw(10) <<
" |";
175 for (
unsigned int i=0; i<nvals; i++)
181 std::stringstream oss;
183 output << std::setw(5) << oss.str();
186 output << std::setw(5) << i;
190 << std::setw(15) << root.
kr 191 << std::setw(15) << root.
V 192 << std::setw(15) << root.
g 193 << std::setw(15) << root.
omega 194 << std::setw(15) << std::real(root.
root)
195 << std::setw(15) << std::imag(root.
root)
196 << std::setw(3) <<
" | ";
199 for (
unsigned int j=0; j<n_participation_vals; j++)
202 << std::setw(2) <<
" ";
205 for (
unsigned int j=0; j<nvals; j++)
208 << std::setw(2) <<
"| " 210 << std::setw(2) <<
" " 212 << std::setw(2) <<
" |";
const ComplexMatrixX & B() const
ComplexVectorX eig_vec_left
std::vector< MAST::FlutterRootBase * > _roots
unsigned int n_roots() const
number of roots in this solution
ComplexMatrixX _Amat
Matrix used for scaling of eigenvectors, and sorting of roots.
const ComplexMatrixX & A() const
virtual void init(const Real kr_ref_val, const Real b_ref, const Complex num, const Complex den, const ComplexMatrixX &Bmat, const ComplexVectorX &evec_right, const ComplexVectorX &evec_left)
initializes the data
Matrix< Complex, Dynamic, 1 > ComplexVectorX
const ComplexVectorX & betas() const
virtual ~UGFlutterSolution()
delete the flutter root objects
const ComplexVectorX & alphas() const
virtual void print(std::ostream &output)
prints the data and modes from this solution
Matrix< Complex, Dynamic, Dynamic > ComplexMatrixX
const MAST::FlutterRootBase & get_root(const unsigned int i) const
const ComplexMatrixX & left_eigenvectors() const
void init(const MAST::UGFlutterSolver &solver, const Real v_ref, const Real b_ref, const MAST::LAPACK_ZGGEV_Base &eig_sol)
initializes the root
Real _ref_val
Reference value of the sweeping parameter for which this solution was obtained.
const ComplexMatrixX & right_eigenvectors() const
virtual void sort(const MAST::FlutterSolutionBase &sol)
sort this root with respect to the given solution from a previous eigen solution. ...
RealVectorX modal_participation
ComplexVectorX eig_vec_right
right and left eigenvevtors
This implements a solver for a single parameter instability problem, for example a flutter solver whe...