1 /*
2 
3     Copyright (C) 2014, The University of Texas at Austin
4 
5     This file is part of libflame and is available under the 3-Clause
6     BSD license, which can be found in the LICENSE file at the top-level
7     directory, or at http://opensource.org/licenses/BSD-3-Clause
8 
9 */
10 
11 #include "FLAME.h"
12 
FLA_Hevdr_check(FLA_Evd_type jobz,FLA_Uplo uplo,FLA_Obj A,FLA_Obj l,FLA_Obj Z)13 FLA_Error FLA_Hevdr_check( FLA_Evd_type jobz, FLA_Uplo uplo, FLA_Obj A, FLA_Obj l, FLA_Obj Z )
14 {
15   FLA_Error e_val;
16 
17   e_val = FLA_Check_valid_evd_type( jobz );
18   FLA_Check_error_code( e_val );
19 
20   e_val = FLA_Check_valid_uplo( uplo );
21   FLA_Check_error_code( e_val );
22 
23   e_val = FLA_Check_floating_object( A );
24   FLA_Check_error_code( e_val );
25 
26   e_val = FLA_Check_nonconstant_object( A );
27   FLA_Check_error_code( e_val );
28 
29   e_val = FLA_Check_identical_object_datatype( A, Z );
30   FLA_Check_error_code( e_val );
31 
32   e_val = FLA_Check_real_object( l );
33   FLA_Check_error_code( e_val );
34 
35   e_val = FLA_Check_identical_object_precision( A, l );
36   FLA_Check_error_code( e_val );
37 
38   e_val = FLA_Check_square( A );
39   FLA_Check_error_code( e_val );
40 
41   e_val = FLA_Check_conformal_dims( FLA_NO_TRANSPOSE, A, Z );
42   FLA_Check_error_code( e_val );
43 
44   e_val = FLA_Check_vector_dim( l, FLA_Obj_length( A ) );
45   FLA_Check_error_code( e_val );
46 
47   e_val = FLA_Check_col_storage( l );
48   FLA_Check_error_code( e_val );
49 
50   return FLA_SUCCESS;
51 }
52 
53