libflame revision_anchor
Functions
FLA_Svd_ext.c File Reference

(r)

Functions

FLA_Error FLA_Svd_ext (FLA_Svd_type jobu, FLA_Trans transu, FLA_Svd_type jobv, FLA_Trans transv, FLA_Obj A, FLA_Obj s, FLA_Obj U, FLA_Obj V)
 

Function Documentation

◆ FLA_Svd_ext()

FLA_Error FLA_Svd_ext ( FLA_Svd_type  jobu,
FLA_Trans  transu,
FLA_Svd_type  jobv,
FLA_Trans  transv,
FLA_Obj  A,
FLA_Obj  s,
FLA_Obj  U,
FLA_Obj  V 
)
28{
30 dim_t n_iter_max = 30;
31 dim_t k_accum = 32;
32 dim_t b_alg = 512;
38 FLA_Obj W; // Dummy variable for partitioning of matrices.
39
40 // Check parameters.
43
44 // Transpose U and V to match dimensions used in SVD.
47 {
51 }
54 {
58 }
59
60 // Partition U and V if necessary.
63
64 if ( m_A >= n_A )
65 {
68 A, s, U, V,
69 k_accum, b_alg );
70
71 // Recover U and V.
72 if ( u_flipped == TRUE )
73 {
74 if ( FLA_Obj_is_complex( U ) )
77 }
78 if ( v_flipped == TRUE )
79 {
80 if ( FLA_Obj_is_complex( V ) )
83 }
84 }
85 else
86 {
87 // Flip A and exchange U and V parameters.
90
91 // Note that U and V are also swapped.
94 A, s, V, U,
95 k_accum, b_alg );
96
97 // Recover A.
99
100 // Recover U and V. Consider a case that U and V are not created.
101 if ( u_flipped == TRUE )
103 else if ( jobu != FLA_SVD_VECTORS_NONE &&
105 if ( FLA_Obj_is_complex( U ) )
106 FLA_Conjugate( U );
107
108 if ( v_flipped == TRUE )
110 else if ( jobv != FLA_SVD_VECTORS_NONE &&
112 if ( FLA_Obj_is_complex( V ) )
113 FLA_Conjugate( V );
114 }
115
116 return r_val;
117}
FLA_Error FLA_Svd_ext_u_unb_var1(FLA_Svd_type jobu, FLA_Svd_type jobv, dim_t n_iter_max, FLA_Obj A, FLA_Obj s, FLA_Obj V, FLA_Obj U, dim_t k_accum, dim_t b_alg)
Definition FLA_Svd_ext_u_unb_var1.c:14
FLA_Error FLA_Svd_ext_check(FLA_Svd_type jobu, FLA_Trans transu, FLA_Svd_type jobv, FLA_Trans transv, FLA_Obj A, FLA_Obj s, FLA_Obj U, FLA_Obj V)
Definition FLA_Svd_ext_check.c:13
FLA_Error FLA_Obj_flip_view(FLA_Obj *obj)
Definition FLA_Obj.c:669
FLA_Error FLA_Obj_flip_base(FLA_Obj *obj)
Definition FLA_Obj.c:647
dim_t FLA_Obj_width(FLA_Obj obj)
Definition FLA_Query.c:123
FLA_Error FLA_Part_1x2(FLA_Obj A, FLA_Obj *A1, FLA_Obj *A2, dim_t nb, FLA_Side side)
Definition FLA_View.c:110
dim_t FLA_Obj_length(FLA_Obj obj)
Definition FLA_Query.c:116
FLA_Bool FLA_Obj_is_complex(FLA_Obj A)
Definition FLA_Query.c:324
unsigned int FLA_Check_error_level(void)
Definition FLA_Check.c:18
dim_t FLA_Obj_min_dim(FLA_Obj obj)
Definition FLA_Query.c:153
int FLA_Error
Definition FLA_type_defs.h:47
unsigned long dim_t
Definition FLA_type_defs.h:71
int FLA_Bool
Definition FLA_type_defs.h:46
FLA_Error FLA_Conjugate(FLA_Obj A)
Definition FLA_Conjugate.c:13
int i
Definition bl1_axmyv2.c:145
Definition FLA_type_defs.h:159

References FLA_Check_error_level(), FLA_Conjugate(), FLA_Obj_flip_base(), FLA_Obj_flip_view(), FLA_Obj_is_complex(), FLA_Obj_length(), FLA_Obj_min_dim(), FLA_Obj_width(), FLA_Part_1x2(), FLA_Svd_ext_check(), FLA_Svd_ext_u_unb_var1(), and i.