arm_kullback_leibler_f64.c 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /* ----------------------------------------------------------------------
  2. * Project: CMSIS DSP Library
  3. * Title: arm_logsumexp_f64.c
  4. * Description: LogSumExp
  5. *
  6. * $Date: 23 April 2021
  7. * $Revision: V1.9.0
  8. *
  9. * Target Processor: Cortex-M and Cortex-A cores
  10. * -------------------------------------------------------------------- */
  11. /*
  12. * Copyright (C) 2010-2021 ARM Limited or its affiliates. All rights reserved.
  13. *
  14. * SPDX-License-Identifier: Apache-2.0
  15. *
  16. * Licensed under the Apache License, Version 2.0 (the License); you may
  17. * not use this file except in compliance with the License.
  18. * You may obtain a copy of the License at
  19. *
  20. * www.apache.org/licenses/LICENSE-2.0
  21. *
  22. * Unless required by applicable law or agreed to in writing, software
  23. * distributed under the License is distributed on an AS IS BASIS, WITHOUT
  24. * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  25. * See the License for the specific language governing permissions and
  26. * limitations under the License.
  27. */
  28. #include "dsp/statistics_functions.h"
  29. #include <limits.h>
  30. #include <math.h>
  31. /**
  32. * @addtogroup Kullback-Leibler
  33. * @{
  34. */
  35. /**
  36. * @brief Kullback-Leibler
  37. *
  38. * @param[in] *pSrcA points to an array of input values for probaility distribution A.
  39. * @param[in] *pSrcB points to an array of input values for probaility distribution B.
  40. * @param[in] blockSize number of samples in the input array.
  41. * @return Kullback-Leibler divergence D(A || B)
  42. *
  43. */
  44. float64_t arm_kullback_leibler_f64(const float64_t * pSrcA, const float64_t * pSrcB, uint32_t blockSize)
  45. {
  46. const float64_t *pInA, *pInB;
  47. uint32_t blkCnt;
  48. float64_t accum, pA,pB;
  49. pInA = pSrcA;
  50. pInB = pSrcB;
  51. blkCnt = blockSize;
  52. accum = 0.0;
  53. while(blkCnt > 0)
  54. {
  55. pA = *pInA++;
  56. pB = *pInB++;
  57. accum += pA * log(pB / pA);
  58. blkCnt--;
  59. }
  60. return(-accum);
  61. }
  62. /**
  63. * @} end of Kullback-Leibler group
  64. */