GNU Radio 3.5.3.2 C++ API
volk_32f_x2_min_32f_a.h
Go to the documentation of this file.
00001 #ifndef INCLUDED_volk_32f_x2_min_32f_a_H
00002 #define INCLUDED_volk_32f_x2_min_32f_a_H
00003 
00004 #include <inttypes.h>
00005 #include <stdio.h>
00006 
00007 #ifdef LV_HAVE_SSE
00008 #include <xmmintrin.h>
00009 /*!
00010   \brief Selects minimum value from each entry between bVector and aVector and store their results in the cVector
00011   \param cVector The vector where the results will be stored
00012   \param aVector The vector to be checked
00013   \param bVector The vector to be checked
00014   \param num_points The number of values in aVector and bVector to be checked and stored into cVector
00015 */
00016 static inline void volk_32f_x2_min_32f_a_sse(float* cVector, const float* aVector, const float* bVector, unsigned int num_points){
00017     unsigned int number = 0;
00018     const unsigned int quarterPoints = num_points / 4;
00019 
00020     float* cPtr = cVector;
00021     const float* aPtr = aVector;
00022     const float* bPtr=  bVector;
00023 
00024     __m128 aVal, bVal, cVal;
00025     for(;number < quarterPoints; number++){
00026       
00027       aVal = _mm_load_ps(aPtr); 
00028       bVal = _mm_load_ps(bPtr);
00029       
00030       cVal = _mm_min_ps(aVal, bVal); 
00031       
00032       _mm_store_ps(cPtr,cVal); // Store the results back into the C container
00033 
00034       aPtr += 4;
00035       bPtr += 4;
00036       cPtr += 4;
00037     }
00038 
00039     number = quarterPoints * 4;
00040     for(;number < num_points; number++){
00041       const float a = *aPtr++;
00042       const float b = *bPtr++;
00043       *cPtr++ = ( a < b ? a : b);
00044     }
00045 }
00046 #endif /* LV_HAVE_SSE */
00047 
00048 #ifdef LV_HAVE_GENERIC
00049 /*!
00050   \brief Selects minimum value from each entry between bVector and aVector and store their results in the cVector
00051   \param cVector The vector where the results will be stored
00052   \param aVector The vector to be checked
00053   \param bVector The vector to be checked
00054   \param num_points The number of values in aVector and bVector to be checked and stored into cVector
00055 */
00056 static inline void volk_32f_x2_min_32f_a_generic(float* cVector, const float* aVector, const float* bVector, unsigned int num_points){
00057     float* cPtr = cVector;
00058     const float* aPtr = aVector;
00059     const float* bPtr=  bVector;
00060     unsigned int number = 0;
00061 
00062     for(number = 0; number < num_points; number++){
00063       const float a = *aPtr++;
00064       const float b = *bPtr++;
00065       *cPtr++ = ( a < b ? a : b);
00066     }
00067 }
00068 #endif /* LV_HAVE_GENERIC */
00069 
00070 #ifdef LV_HAVE_ORC
00071 /*!
00072   \brief Selects minimum value from each entry between bVector and aVector and store their results in the cVector
00073   \param cVector The vector where the results will be stored
00074   \param aVector The vector to be checked
00075   \param bVector The vector to be checked
00076   \param num_points The number of values in aVector and bVector to be checked and stored into cVector
00077 */
00078 extern void volk_32f_x2_min_32f_a_orc_impl(float* cVector, const float* aVector, const float* bVector, unsigned int num_points);
00079 static inline void volk_32f_x2_min_32f_a_orc(float* cVector, const float* aVector, const float* bVector, unsigned int num_points){
00080     volk_32f_x2_min_32f_a_orc_impl(cVector, aVector, bVector, num_points);
00081 }
00082 #endif /* LV_HAVE_ORC */
00083 
00084 
00085 #endif /* INCLUDED_volk_32f_x2_min_32f_a_H */