首页 > 解决方案 > matlab生成的C函数用途不明

问题描述

有人可以帮我理解这个功能在做什么吗?我猜它在做某种幂运算。我在 google 上搜索了这个名字,它似乎来自 matlab 生成的一些 C 代码。有谁知道这个功能应该做什么?SNF 代表什么?谢谢你。

double rt_powd_snf(double u0, double u1)
{
  double y;
  double d0;
  double d1;
  if (isnan(u0) || isnan(u1))
  {
    y = NAN;
  }
  else
  {
    d0 = fabs(u0);
    d1 = fabs(u1);
    if (isinf(u1))
    {
      if (d0 == 1.0)
      {
        y = 1.0;
      }
      else if (d0 > 1.0)
      {
        if (u1 > 0.0)
        {
          y = INFINITY;
        }
        else
        {
          y = 0.0;
        }
      }
      else if (u1 > 0.0)
      {
        y = 0.0;
      }
      else
      {
        y = INFINITY;
      }
    }
    else if (d1 == 0.0)
    {
      y = 1.0;
    }
    else if (d1 == 1.0)
    {
      if (u1 > 0.0)
      {
        y = u0;
      }
      else
      {
        y = 1.0 / u0;
      }
    }
    else if (u1 == 2.0)
    {
      y = u0 * u0;
    }
    else if ((u1 == 0.5) && (u0 >= 0.0))
    {
      y = sqrt(u0);
    }
    else if ((u0 < 0.0) && (u1 > floor(u1)))
    {
      y = NAN;
    }
    else
    {
      y = pow(u0, u1);
    }
  }

  return y;
}

标签: c++cmatlabmathsignal-processing

解决方案


此功能将一个提升double到另一个的幂double

您可以通过pow底部的调用看到这一点:

y = pow(u0, u1);

它还处理各种特殊情况,干净地处理非数字和无限输入,并有效地处理特殊值。

powd意味着它是一个使用双打的幂函数。从文档来看,_snf意味着它可以处理非有限数字。rt_前缀来自配置变量MAT文件变量名修饰符。我猜这代表“运行时”,但这不是成立的。

在代码中,d0d1是输入u0和的绝对(负数变为正数)版本u1。结果在y.


遍历代码:

  • 如果底数或指数是 NAN
    • 返回南
  • 如果指数是无限的
    • 如果绝对基数是 1.0
      • 返回 1.0
    • 如果绝对基数大于 1.0
      • 如果指数为正(无穷大)
        • 返回无限
      • 否则指数为负(无穷大)
        • 返回 0.0
    • 否则绝对基数小于 1.0
      • 如果指数为正(无穷大)
        • 返回 0.0
      • 否则指数为负(无穷大)
        • 返回无限
  • 如果绝对指数为 0.0
    • 返回 1.0
  • 如果绝对指数为 1.0
    • 如果指数为正 (1.0)
      • 返回基地
    • 否则指数为负 (1.0)
      • 返回 1.0 / 基础
  • 如果指数是 2.0
    • 返回基本时间本身
  • 如果指数为 0.5 且底数为非负数
    • 返回基数的平方根
  • 如果底数为负且指数不是整数
    • 返回南
  • 否则情况不特殊
    • 返回结果pow(u0, u1)

推荐阅读