20#ifndef AMESOS2_SUPERLUMT_TYPEMAP_HPP
21#define AMESOS2_SUPERLUMT_TYPEMAP_HPP
25#include <Teuchos_as.hpp>
26#ifdef HAVE_TEUCHOS_COMPLEX
27#include <Teuchos_SerializationTraits.hpp>
30#include "Amesos2_TypeMap.hpp"
38#undef __SUPERLU_SUPERMATRIX
39#include "supermatrix.h"
41#ifdef HAVE_TEUCHOS_COMPLEX
44#undef __SUPERLU_SCOMPLEX
45#undef SCOMPLEX_INCLUDE
46#include "slu_scomplex.h"
50#undef __SUPERLU_DCOMPLEX
51#undef DCOMPLEX_INCLUDE
52#include "slu_dcomplex.h"
60 template <
typename slu_scalar_t,
typename slu_mag_t>
61 struct slu_mt_mult {};
66 struct slu_mt_mult<T,T> : std::multiplies<T> {};
68#ifdef HAVE_TEUCHOS_COMPLEX
72 struct slu_mt_mult<C::complex,float>
74 C::complex operator()(C::complex amesos_c,
float amesos_f) {
76 cs_mult(&amesos_cr, &amesos_c, amesos_f);
82 struct slu_mt_mult<C::complex,C::complex>
84 C::complex operator()(C::complex amesos_c1, C::complex amesos_c2) {
86 cc_mult(&amesos_cr, &amesos_c1, &amesos_c2);
92 struct slu_mt_mult<Z::doublecomplex,double>
94 Z::doublecomplex operator()(Z::doublecomplex amesos_z,
double amesos_d) {
95 Z::doublecomplex amesos_zr;
96 zd_mult(&amesos_zr, &amesos_z, amesos_d);
102 struct slu_mt_mult<Z::doublecomplex,Z::doublecomplex>
104 Z::doublecomplex operator()(Z::doublecomplex amesos_z1, Z::doublecomplex amesos_z2) {
105 Z::doublecomplex amesos_zr;
106 zz_mult(&amesos_zr, &amesos_z1, &amesos_z2);
113#ifdef HAVE_TEUCHOS_COMPLEX
128template <
typename TypeFrom>
129class ValueTypeConversionTraits<SLUMT::C::complex, TypeFrom>
132 static SLUMT::C::complex convert(
const TypeFrom t )
134 SLUMT::C::complex ret;
135 ret.r = Teuchos::as<float>(t.real());
136 ret.i = Teuchos::as<float>(t.imag());
140 static SLUMT::C::complex safeConvert(
const TypeFrom t )
142 SLUMT::C::complex ret;
143 ret.r = Teuchos::as<float>(t.real());
144 ret.i = Teuchos::as<float>(t.imag());
150template <
typename TypeFrom>
151class ValueTypeConversionTraits<SLUMT::Z::doublecomplex, TypeFrom>
154 static SLUMT::Z::doublecomplex convert(
const TypeFrom t )
156 SLUMT::Z::doublecomplex ret;
157 ret.r = Teuchos::as<double>(t.real());
158 ret.i = Teuchos::as<double>(t.imag());
162 static SLUMT::Z::doublecomplex safeConvert(
const TypeFrom t )
164 SLUMT::Z::doublecomplex ret;
165 ret.r = Teuchos::as<double>(t.real());
166 ret.i = Teuchos::as<double>(t.imag());
173template <
typename TypeTo>
174class ValueTypeConversionTraits<TypeTo, SLUMT::C::complex>
177 static TypeTo convert(
const SLUMT::C::complex t )
179 typedef typename TypeTo::value_type value_type;
180 value_type ret_r = Teuchos::as<value_type>( t.r );
181 value_type ret_i = Teuchos::as<value_type>( t.i );
182 return ( TypeTo( ret_r, ret_i ) );
186 static TypeTo safeConvert(
const SLUMT::C::complex t )
188 typedef typename TypeTo::value_type value_type;
189 value_type ret_r = Teuchos::as<value_type>( t.r );
190 value_type ret_i = Teuchos::as<value_type>( t.i );
191 return ( TypeTo( ret_r, ret_i ) );
196template <
typename TypeTo>
197class ValueTypeConversionTraits<TypeTo, SLUMT::Z::doublecomplex>
200 static TypeTo convert(
const SLUMT::Z::doublecomplex t )
202 typedef typename TypeTo::value_type value_type;
203 value_type ret_r = Teuchos::as<value_type>( t.r );
204 value_type ret_i = Teuchos::as<value_type>( t.i );
205 return ( TypeTo( ret_r, ret_i ) );
209 static TypeTo safeConvert(
const SLUMT::Z::doublecomplex t )
211 typedef typename TypeTo::value_type value_type;
212 value_type ret_r = Teuchos::as<value_type>( t.r );
213 value_type ret_i = Teuchos::as<value_type>( t.i );
214 return ( TypeTo( ret_r, ret_i ) );
218template <
typename Ordinal>
219class SerializationTraits<Ordinal,SLUMT::C::complex>
220 :
public DirectSerializationTraits<Ordinal,SLUMT::C::complex>
223template <
typename Ordinal>
224class SerializationTraits<Ordinal,SLUMT::Z::doublecomplex>
225 :
public DirectSerializationTraits<Ordinal,SLUMT::Z::doublecomplex>
241 ostream& operator<<(ostream& out,
const SLUMT::C::complex c);
243 ostream& operator<<(ostream& out,
const SLUMT::Z::doublecomplex z);
253template <
class,
class>
class Superlumt;
260struct TypeMap<Superlumt,float>
262 static SLUMT::Dtype_t dtype;
264 typedef float magnitude_type;
269struct TypeMap<Superlumt,double>
271 static SLUMT::Dtype_t dtype;
273 typedef double magnitude_type;
277#ifdef HAVE_TEUCHOS_COMPLEX
279struct TypeMap<Superlumt,std::complex<float> >
281 static SLUMT::Dtype_t dtype;
282 typedef SLUMT::C::complex type;
283 typedef float magnitude_type;
288struct TypeMap<Superlumt,std::complex<double> >
290 static SLUMT::Dtype_t dtype;
291 typedef SLUMT::Z::doublecomplex type;
292 typedef double magnitude_type;
297struct TypeMap<Superlumt,SLUMT::C::complex>
299 static SLUMT::Dtype_t dtype;
300 typedef SLUMT::C::complex type;
301 typedef float magnitude_type;
306struct TypeMap<Superlumt,SLUMT::Z::doublecomplex>
308 static SLUMT::Dtype_t dtype;
309 typedef SLUMT::Z::doublecomplex type;
310 typedef double magnitude_type;