GNU Radio 3.5.3.2 C++ API
|
00001 #ifndef INCLUDED_volk_32fc_deinterleave_64f_x2_a_H 00002 #define INCLUDED_volk_32fc_deinterleave_64f_x2_a_H 00003 00004 #include <inttypes.h> 00005 #include <stdio.h> 00006 00007 #ifdef LV_HAVE_SSE2 00008 #include <emmintrin.h> 00009 /*! 00010 \brief Deinterleaves the lv_32fc_t vector into double I & Q vector data 00011 \param complexVector The complex input vector 00012 \param iBuffer The I buffer output data 00013 \param qBuffer The Q buffer output data 00014 \param num_points The number of complex data values to be deinterleaved 00015 */ 00016 static inline void volk_32fc_deinterleave_64f_x2_a_sse2(double* iBuffer, double* qBuffer, const lv_32fc_t* complexVector, unsigned int num_points){ 00017 unsigned int number = 0; 00018 00019 const float* complexVectorPtr = (float*)complexVector; 00020 double* iBufferPtr = iBuffer; 00021 double* qBufferPtr = qBuffer; 00022 00023 const unsigned int halfPoints = num_points / 2; 00024 __m128 cplxValue, fVal; 00025 __m128d dVal; 00026 00027 for(;number < halfPoints; number++){ 00028 00029 cplxValue = _mm_load_ps(complexVectorPtr); 00030 complexVectorPtr += 4; 00031 00032 // Arrange in i1i2i1i2 format 00033 fVal = _mm_shuffle_ps(cplxValue, cplxValue, _MM_SHUFFLE(2,0,2,0)); 00034 dVal = _mm_cvtps_pd(fVal); 00035 _mm_store_pd(iBufferPtr, dVal); 00036 00037 // Arrange in q1q2q1q2 format 00038 fVal = _mm_shuffle_ps(cplxValue, cplxValue, _MM_SHUFFLE(3,1,3,1)); 00039 dVal = _mm_cvtps_pd(fVal); 00040 _mm_store_pd(qBufferPtr, dVal); 00041 00042 iBufferPtr += 2; 00043 qBufferPtr += 2; 00044 } 00045 00046 number = halfPoints * 2; 00047 for(; number < num_points; number++){ 00048 *iBufferPtr++ = *complexVectorPtr++; 00049 *qBufferPtr++ = *complexVectorPtr++; 00050 } 00051 } 00052 #endif /* LV_HAVE_SSE */ 00053 00054 #ifdef LV_HAVE_GENERIC 00055 /*! 00056 \brief Deinterleaves the lv_32fc_t vector into double I & Q vector data 00057 \param complexVector The complex input vector 00058 \param iBuffer The I buffer output data 00059 \param qBuffer The Q buffer output data 00060 \param num_points The number of complex data values to be deinterleaved 00061 */ 00062 static inline void volk_32fc_deinterleave_64f_x2_a_generic(double* iBuffer, double* qBuffer, const lv_32fc_t* complexVector, unsigned int num_points){ 00063 unsigned int number = 0; 00064 const float* complexVectorPtr = (float*)complexVector; 00065 double* iBufferPtr = iBuffer; 00066 double* qBufferPtr = qBuffer; 00067 00068 for(number = 0; number < num_points; number++){ 00069 *iBufferPtr++ = (double)*complexVectorPtr++; 00070 *qBufferPtr++ = (double)*complexVectorPtr++; 00071 } 00072 } 00073 #endif /* LV_HAVE_GENERIC */ 00074 00075 00076 00077 00078 #endif /* INCLUDED_volk_32fc_deinterleave_64f_x2_a_H */