|
libflame
revision_anchor
|
Functions | |
| FLA_Error | FLASH_CAQR_UT_inc_solve (dim_t p, FLA_Obj A, FLA_Obj ATW, FLA_Obj R, FLA_Obj RTW, FLA_Obj B, FLA_Obj X) |
| FLA_Error FLASH_CAQR_UT_inc_solve | ( | dim_t | p, |
| FLA_Obj | A, | ||
| FLA_Obj | ATW, | ||
| FLA_Obj | R, | ||
| FLA_Obj | RTW, | ||
| FLA_Obj | B, | ||
| FLA_Obj | X | ||
| ) |
References FLA_CAQR_UT_inc_solve_check(), FLA_Check_error_level(), FLA_ONE, FLASH_Apply_CAQ_UT_inc(), FLASH_Apply_CAQ_UT_inc_create_workspace(), FLASH_Copy(), FLASH_Obj_create_copy_of(), FLASH_Obj_free(), FLASH_Obj_scalar_width(), FLASH_Part_create_2x1(), FLASH_Part_free_2x1(), and FLASH_Trsm().
{
FLA_Obj W, Y;
FLA_Obj RT, RB;
FLA_Obj YT, YB;
// Check parameters.
if ( FLA_Check_error_level() >= FLA_MIN_ERROR_CHECKING )
FLA_CAQR_UT_inc_solve_check( p, A, ATW, R, RTW, B, X );
FLASH_Apply_CAQ_UT_inc_create_workspace( p, RTW, B, &W );
FLASH_Obj_create_copy_of( FLA_NO_TRANSPOSE, B, &Y );
// Create a temporary hierarchical view of only the top n-by-n part of R in
// case m > n so that RT captures the upper triangle. We do the same for Y
// to ensure conformality.
FLASH_Part_create_2x1( R, &RT,
&RB, FLASH_Obj_scalar_width( R ), FLA_TOP );
FLASH_Part_create_2x1( Y, &YT,
&YB, FLASH_Obj_scalar_width( R ), FLA_TOP );
FLASH_Apply_CAQ_UT_inc( p,
FLA_LEFT, FLA_CONJ_TRANSPOSE, FLA_FORWARD, FLA_COLUMNWISE,
A, ATW, R, RTW, W, Y );
FLASH_Trsm( FLA_LEFT, FLA_UPPER_TRIANGULAR, FLA_NO_TRANSPOSE, FLA_NONUNIT_DIAG,
FLA_ONE, RT, YT );
FLASH_Copy( YT, X );
// Free the temporary hierarchical views.
FLASH_Part_free_2x1( &RT,
&RB );
FLASH_Part_free_2x1( &YT,
&YB );
FLASH_Obj_free( &Y );
FLASH_Obj_free( &W );
return FLA_SUCCESS;
}
1.7.6.1