// -*- C++ -*-
//
// Unoptimized reimplementation of vectorized mathematica functions
// from the IBM mass library.
//
// Copyright (C) 1996-2011 Jakob Schiotz and Center for Individual
// Nanoparticle Functionality, Department of Physics, Technical
// University of Denmark. Email: schiotz@fysik.dtu.dk
//
// This file is part of Asap version 3.
// Asap is released under the GNU Lesser Public License (LGPL) version 3.
// However, the parts of Asap distributed within the OpenKIM project
// (including this file) are also released under the Common Development
// and Distribution License (CDDL) version 1.0.
//
// This program is free software: you can redistribute it and/or
// modify it under the terms of the GNU Lesser General Public License
// version 3 as published by the Free Software Foundation. Permission
// to use other versions of the GNU Lesser General Public License may
// granted by Jakob Schiotz or the head of department of the
// Department of Physics, Technical University of Denmark, as
// described in section 14 of the GNU General Public License.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// and the GNU Lesser Public License along with this program. If not,
// see .
#include
namespace ASAPSPACE {
inline void vsqrt(double res[], const double a[], const int *n)
{
int nn = *n;
for (int i = 0; i < nn; i++)
res[i] = sqrt(a[i]);
}
inline void vexp(double res[], const double a[], const int *n)
{
int nn = *n;
for (int i = 0; i < nn; i++)
res[i] = exp(a[i]);
}
inline void vrec(double res[], const double a[], const int *n)
{
int nn = *n;
for (int i = 0; i < nn; i++)
res[i] = 1.0 / a[i];
}
inline void vlog(double res[], const double a[], const int *n)
{
int nn = *n;
for (int i = 0; i < nn; i++)
res[i] = log(a[i]);
}
} // end namespace