]> Gitweb @ Texas Instruments - Open Source Git Repositories - git.TI.com/gitweb - dense-linear-algebra-libraries/linalg.git/blobdiff - src/ti/linalg/blis/frame/3/symm/4mh/bli_symm4mh.c
Sync with external git. Should be the other way around.
[dense-linear-algebra-libraries/linalg.git] / src / ti / linalg / blis / frame / 3 / symm / 4mh / bli_symm4mh.c
diff --git a/src/ti/linalg/blis/frame/3/symm/4mh/bli_symm4mh.c b/src/ti/linalg/blis/frame/3/symm/4mh/bli_symm4mh.c
new file mode 100644 (file)
index 0000000..ac62aea
--- /dev/null
@@ -0,0 +1,107 @@
+/*
+
+   BLIS    
+   An object-based framework for developing high-performance BLAS-like
+   libraries.
+
+   Copyright (C) 2014, The University of Texas at Austin
+
+   Redistribution and use in source and binary forms, with or without
+   modification, are permitted provided that the following conditions are
+   met:
+    - Redistributions of source code must retain the above copyright
+      notice, this list of conditions and the following disclaimer.
+    - Redistributions in binary form must reproduce the above copyright
+      notice, this list of conditions and the following disclaimer in the
+      documentation and/or other materials provided with the distribution.
+    - Neither the name of The University of Texas at Austin nor the names
+      of its contributors may be used to endorse or promote products
+      derived from this software without specific prior written permission.
+
+   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+   "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+   A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+   HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+*/
+
+#include "blis.h"
+
+//
+// Define object-based interface.
+//
+void bli_symm4mh( side_t  side,
+                 obj_t*  alpha,
+                 obj_t*  a,
+                 obj_t*  b,
+                 obj_t*  beta,
+                 obj_t*  c )
+{
+       // Since 4mh only applies to the complex domain, we use the regular
+       // implementation for real domain cases.
+       if ( bli_obj_is_complex( *c ) )
+               bli_symm4mh_entry( side, alpha, a, b, beta, c );
+       else
+               bli_symm_entry( side, alpha, a, b, beta, c );
+}
+
+//
+// Define BLAS-like interfaces with homogeneous-typed operands.
+//
+#undef  GENTFUNC
+#define GENTFUNC( ctype, ch, opname, varname ) \
+\
+void PASTEMAC(ch,opname)( \
+                          side_t  side, \
+                          uplo_t  uploa, \
+                          conj_t  conja, \
+                          trans_t transb, \
+                          dim_t   m, \
+                          dim_t   n, \
+                          ctype*  alpha, \
+                          ctype*  a, inc_t rs_a, inc_t cs_a, \
+                          ctype*  b, inc_t rs_b, inc_t cs_b, \
+                          ctype*  beta, \
+                          ctype*  c, inc_t rs_c, inc_t cs_c  \
+                        ) \
+{ \
+       const num_t dt = PASTEMAC(ch,type); \
+\
+       obj_t       alphao, ao, bo, betao, co; \
+\
+       dim_t       mn_a; \
+       dim_t       m_b, n_b; \
+\
+       bli_set_dim_with_side(   side,   m, n, mn_a ); \
+       bli_set_dims_with_trans( transb, m, n, m_b, n_b ); \
+\
+       bli_obj_create_1x1_with_attached_buffer( dt, alpha, &alphao ); \
+       bli_obj_create_1x1_with_attached_buffer( dt, beta,  &betao  ); \
+\
+       bli_obj_create_with_attached_buffer( dt, mn_a, mn_a, a, rs_a, cs_a, &ao ); \
+       bli_obj_create_with_attached_buffer( dt, m_b,  n_b,  b, rs_b, cs_b, &bo ); \
+       bli_obj_create_with_attached_buffer( dt, m,    n,    c, rs_c, cs_c, &co ); \
+\
+       bli_obj_set_uplo( uploa, ao ); \
+       bli_obj_set_conj( conja, ao ); \
+       bli_obj_set_conjtrans( transb, bo ); \
+\
+       bli_obj_set_struc( BLIS_SYMMETRIC, ao ); \
+\
+       PASTEMAC0(opname)( side, \
+                          &alphao, \
+                          &ao, \
+                          &bo, \
+                          &betao, \
+                          &co ); \
+}
+
+INSERT_GENTFUNC_BASIC( symm4mh, symm4mh )
+