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_Trsmsx_check(FLA_Side side,FLA_Uplo uplo,FLA_Trans trans,FLA_Diag diag,FLA_Obj alpha,FLA_Obj A,FLA_Obj B,FLA_Obj beta,FLA_Obj C)13 FLA_Error FLA_Trsmsx_check( FLA_Side side, FLA_Uplo uplo, FLA_Trans trans, FLA_Diag diag, FLA_Obj alpha, FLA_Obj A, FLA_Obj B, FLA_Obj beta, FLA_Obj C )
14 {
15 FLA_Error e_val;
16
17 e_val = FLA_Check_valid_leftright_side( side );
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_valid_trans( trans );
24 FLA_Check_error_code( e_val );
25
26 e_val = FLA_Check_valid_diag( diag );
27 FLA_Check_error_code( e_val );
28
29 e_val = FLA_Check_floating_object( A );
30 FLA_Check_error_code( e_val );
31
32 e_val = FLA_Check_nonconstant_object( A );
33 FLA_Check_error_code( e_val );
34
35 e_val = FLA_Check_identical_object_datatype( A, B );
36 FLA_Check_error_code( e_val );
37
38 e_val = FLA_Check_identical_object_datatype( A, C );
39 FLA_Check_error_code( e_val );
40
41 e_val = FLA_Check_consistent_object_datatype( A, alpha );
42 FLA_Check_error_code( e_val );
43
44 e_val = FLA_Check_consistent_object_datatype( A, beta );
45 FLA_Check_error_code( e_val );
46
47 e_val = FLA_Check_if_scalar( alpha );
48 FLA_Check_error_code( e_val );
49
50 e_val = FLA_Check_if_scalar( beta );
51 FLA_Check_error_code( e_val );
52
53 e_val = FLA_Check_square( A );
54 FLA_Check_error_code( e_val );
55
56 if ( side == FLA_LEFT )
57 {
58 e_val = FLA_Check_matrix_matrix_dims( FLA_NO_TRANSPOSE, FLA_NO_TRANSPOSE, A, B, C );
59 FLA_Check_error_code( e_val );
60 }
61 else
62 {
63 e_val = FLA_Check_matrix_matrix_dims( FLA_NO_TRANSPOSE, FLA_NO_TRANSPOSE, B, A, C );
64 FLA_Check_error_code( e_val );
65 }
66
67 return FLA_SUCCESS;
68 }
69
70