Unverified Commit 4717c840 authored by Peter Eastman's avatar Peter Eastman Committed by GitHub
Browse files

Use portable SIMD vectors as a backup (#4328)

* Use portable SIMD vectors as a backup

* Remove old file

* Try to fix compilation error on Windows
parent 5739788a
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
* Biological Structures at Stanford, funded under the NIH Roadmap for * * Biological Structures at Stanford, funded under the NIH Roadmap for *
* Medical Research, grant U54 GM072970. See https://simtk.org. * * Medical Research, grant U54 GM072970. See https://simtk.org. *
* * * *
* Portions copyright (c) 2014-2018 Stanford University and the Authors. * * Portions copyright (c) 2014-2023 Stanford University and the Authors. *
* Authors: Peter Eastman * * Authors: Peter Eastman *
* Contributors: * * Contributors: *
* * * *
...@@ -36,8 +36,10 @@ ...@@ -36,8 +36,10 @@
#include "vectorize_neon.h" #include "vectorize_neon.h"
#elif defined(__PPC__) #elif defined(__PPC__)
#include "vectorize_ppc.h" #include "vectorize_ppc.h"
#else #elif defined(__SSE__) || defined(_M_IX86) || defined(_M_AMD64)
#include "vectorize_sse.h" #include "vectorize_sse.h"
#else
#include "vectorize_portable.h"
#endif #endif
#endif /*OPENMM_VECTORIZE_H_*/ #endif /*OPENMM_VECTORIZE_H_*/
#ifndef OPENMM_VECTORIZE_PNACL_H_ #ifndef OPENMM_VECTORIZE_PORTABLE_H_
#define OPENMM_VECTORIZE_PNACL_H_ #define OPENMM_VECTORIZE_PORTABLE_H_
/* -------------------------------------------------------------------------- * /* -------------------------------------------------------------------------- *
* OpenMM * * OpenMM *
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
* Biological Structures at Stanford, funded under the NIH Roadmap for * * Biological Structures at Stanford, funded under the NIH Roadmap for *
* Medical Research, grant U54 GM072970. See https://simtk.org. * * Medical Research, grant U54 GM072970. See https://simtk.org. *
* * * *
* Portions copyright (c) 2013-2015 Stanford University and the Authors. * * Portions copyright (c) 2013-2023 Stanford University and the Authors. *
* Authors: Peter Eastman * * Authors: Peter Eastman *
* Contributors: * * Contributors: *
* * * *
...@@ -362,7 +362,7 @@ static inline fvec4 operator/(float v1, fvec4 v2) { ...@@ -362,7 +362,7 @@ static inline fvec4 operator/(float v1, fvec4 v2) {
// Operations for blending fvec4s based on an ivec4. // Operations for blending fvec4s based on an ivec4.
static inline fvec4 blend(fvec4 v1, fvec4 v2, __m128i mask) { static inline fvec4 blend(fvec4 v1, fvec4 v2, __m128i mask) {
return (__m128) ((mask&(__m128i)v2) + ((ivec4(0xFFFFFFFF)-ivec4(mask))&(__m128i)v1)); return mask ? v2.val : v1.val;
} }
static inline fvec4 blendZero(fvec4 v, ivec4 mask) { static inline fvec4 blendZero(fvec4 v, ivec4 mask) {
...@@ -454,5 +454,5 @@ static inline fvec4 reduceToVec3(fvec4 x, fvec4 y, fvec4 z) { ...@@ -454,5 +454,5 @@ static inline fvec4 reduceToVec3(fvec4 x, fvec4 y, fvec4 z) {
return fvec4(nx, ny, nz, 0.0); return fvec4(nx, ny, nz, 0.0);
} }
#endif /*OPENMM_VECTORIZE_PNACL_H_*/ #endif /*OPENMM_VECTORIZE_PORTABLE_H_*/
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment