Blame test/mpi/cxx/coll/arcomplex.cxx

Packit 0848f5
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil ; -*- */
Packit 0848f5
/*
Packit 0848f5
 *
Packit 0848f5
 *  (C) 2008 by Argonne National Laboratory.
Packit 0848f5
 *      See COPYRIGHT in top-level directory.
Packit 0848f5
 */
Packit 0848f5
Packit 0848f5
#include "mpi.h"
Packit 0848f5
#include "mpitestconf.h"
Packit 0848f5
#ifdef HAVE_IOSTREAM
Packit 0848f5
// Not all C++ compilers have iostream instead of iostream.h
Packit 0848f5
#include <iostream>
Packit 0848f5
#ifdef HAVE_NAMESPACE_STD
Packit 0848f5
// Those that do often need the std namespace; otherwise, a bare "cout"
Packit 0848f5
// is likely to fail to compile
Packit 0848f5
using namespace std;
Packit 0848f5
#endif
Packit 0848f5
#else
Packit 0848f5
#include <iostream.h>
Packit 0848f5
#endif
Packit 0848f5
#include <complex>
Packit 0848f5
#include "mpitestcxx.h"
Packit 0848f5
Packit 0848f5
int main( int argc, char **argv )
Packit 0848f5
{
Packit 0848f5
    MPI::Intracomm comm = MPI::COMM_WORLD;
Packit 0848f5
    int errs = 0;
Packit 0848f5
    int size, rank;
Packit 0848f5
    long sum;
Packit 0848f5
    complex<float> c[2], c_out[2];
Packit 0848f5
    complex<double> cd[2], cd_out[2];
Packit 0848f5
#ifdef HAVE_LONG_DOUBLE
Packit 0848f5
    complex<long double> cld[2], cld_out[2];
Packit 0848f5
    MTEST_VG_MEM_INIT(cld, 2 * sizeof(complex<long double>));
Packit 0848f5
#endif
Packit 0848f5
Packit 0848f5
    MTest_Init( );
Packit 0848f5
Packit 0848f5
    size = comm.Get_size();
Packit 0848f5
    rank = comm.Get_rank();
Packit 0848f5
    
Packit 0848f5
    c[0]   = ((float)rank)*complex<float>(1,2);
Packit 0848f5
    c[1]   = ((float)rank)*complex<float>(-1,4);
Packit 0848f5
    cd[0]  = ((double)rank)*complex<double>(1,2);
Packit 0848f5
    cd[1]  = ((double)rank)*complex<double>(-1,4);
Packit 0848f5
#ifdef HAVE_LONG_DOUBLE
Packit 0848f5
    cld[0] = ((long double)rank)*complex<long double>(1,2);
Packit 0848f5
    cld[1] = ((long double)rank)*complex<long double>(-1,4);
Packit 0848f5
#endif
Packit 0848f5
    
Packit 0848f5
    // Sums are easy - real and imaginary parts separate
Packit 0848f5
    // result should be sum(0:size-1) *{ complex(1,2), complex(-1,4) }
Packit 0848f5
    // The sum is (size*(size-1))/2
Packit 0848f5
    comm.Allreduce( c, c_out, 2, MPI::COMPLEX, MPI::SUM );
Packit 0848f5
    sum = (size * (size-1) ) / 2;
Packit 0848f5
    if (c_out[0] != ((float)sum) * complex<float>(1,2)) {
Packit 0848f5
	errs++;
Packit 0848f5
	cout << "c_out[0] was " << c_out[0] << " expected " << 
Packit 0848f5
	    ((float)sum) * complex<float>(1,2);
Packit 0848f5
    }
Packit 0848f5
    if (c_out[1] != ((float)sum) * complex<float>(-1,4)) {
Packit 0848f5
	errs++;
Packit 0848f5
	cout << "c_out[1] was " << c_out[1] << " expected " << 
Packit 0848f5
	    ((float)sum) * complex<float>(-1,4);
Packit 0848f5
    }
Packit 0848f5
    comm.Allreduce( cd, cd_out, 2, MPI::DOUBLE_COMPLEX, MPI::SUM );
Packit 0848f5
    if (cd_out[0] != ((double)sum) * complex<double>(1,2)) {
Packit 0848f5
	errs++;
Packit 0848f5
	cout << "cd_out[0] was " << cd_out[0] << " expected " << 
Packit 0848f5
	    ((double)sum) * complex<double>(1,2);
Packit 0848f5
    }
Packit 0848f5
    if (cd_out[1] != ((double)sum) * complex<double>(-1,4)) {
Packit 0848f5
	errs++;
Packit 0848f5
	cout << "cd_out[1] was " << cd_out[1] << " expected " << 
Packit 0848f5
	    ((double)sum) * complex<double>(-1,4);
Packit 0848f5
    }
Packit 0848f5
#ifdef HAVE_LONG_DOUBLE
Packit 0848f5
    comm.Allreduce( cld, cld_out, 2, MPI::LONG_DOUBLE_COMPLEX, MPI::SUM );
Packit 0848f5
    if (cld_out[0] != ((long double)sum) * complex<long double>(1,2)) {
Packit 0848f5
	errs++;
Packit 0848f5
	cout << "cld_out[0] was " << cld_out[0] << " expected " << 
Packit 0848f5
	    ((long double)sum) * complex<long double>(1,2);
Packit 0848f5
    }
Packit 0848f5
    if (cld_out[1] != ((long double)sum) * complex<long double>(-1,4)) {
Packit 0848f5
	errs++;
Packit 0848f5
	cout << "cld_out[1] was " << cld_out[1] << " expected " << 
Packit 0848f5
	    ((long double)sum) * complex<long double>(-1,4);
Packit 0848f5
    }
Packit 0848f5
#endif
Packit 0848f5
Packit 0848f5
    MTest_Finalize( errs );
Packit 0848f5
    MPI::Finalize();
Packit 0848f5
    return 0;
Packit 0848f5
}