⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bias_mul.c

📁 Interval Arithmetic Toolbox for Matlab
💻 C
字号:
/**********************************************************************
 *  bias_mul - mul with appropiate use of i/o MATLAB - BIAS - MATLAB
 *   -- interval --  PROFIL/BIAS storage (ultimate fast version)
 *
 *  Version: 1.01
 *  Date: 23.1.1998
 *  Author(s): Jens Zemke
 *********************************************************************/

#include <mex.h>
#include "Bias2.h"
#include "types.h"

void mexFunction(int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[])
{
  BIASINTERVAL *pR;
  BIASINTERVAL *pA;
  BIASINTERVAL *pB;
  double *pa;
  double *pb;
  unsigned int Arows, Acols, Brows, Bcols;
  int Aclass, Bclass;

  BiasInit();

  Aclass = (int) *mxGetPr(prhs[0]);
  Bclass = (int) *mxGetPr(prhs[2]);

  if ((Aclass == DouBLe) && (Bclass == INTerval))
  {
    Arows = mxGetM(prhs[1]);
    Acols = mxGetN(prhs[1]);
    Brows = mxGetM(prhs[3])/2;
    Bcols = mxGetN(prhs[3]);

    if (Acols == Brows)
    {

      pa =                  mxGetPr(prhs[1]);
      pB = (BIASINTERVAL *) mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Arows * 2, Bcols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulMIMR(pR, pB, pa, Bcols, Brows, Arows);

      return;
    }

    if ((Acols == 1) && (Arows == 1))
    {

      pa =                  mxGetPr(prhs[1]);
      pB = (BIASINTERVAL *) mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Brows * 2, Bcols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulRMI(pR, pa, pB, Bcols, Brows);

      return;
    }

    if ((Bcols == 1) && (Brows == 1))
    {

      pa =                  mxGetPr(prhs[1]);
      pB = (BIASINTERVAL *) mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Arows * 2, Acols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulIMR(pR, pB, pa, Acols, Arows);

      return;
    }

    plhs[0] = mxCreateString("Matrix dimensions must agree."); return;

  }

  if ((Aclass == DouBLe) && (Bclass == DouBLe))
  {

    Arows = mxGetM(prhs[1]);
    Acols = mxGetN(prhs[1]);
    Brows = mxGetM(prhs[3]);
    Bcols = mxGetN(prhs[3]);

    if (Acols == Brows)
    {

      pa =                  mxGetPr(prhs[1]);
      pb =                  mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Arows * 2, Bcols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulMRMR(pR, pb, pa, Bcols, Brows, Arows);

      return;
    }

    if ((Acols == 1) && (Arows == 1))
    {

      pa =                  mxGetPr(prhs[1]);
      pb =                  mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Brows * 2, Bcols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulRMR(pR, pa, pb, Bcols, Brows);

      return;
    }

    if ((Bcols == 1) && (Brows == 1))
    {

      pa =                  mxGetPr(prhs[1]);
      pb =                  mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Arows * 2, Acols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulRMR(pR, pb, pa, Acols, Arows);

      return;
    }

    plhs[0] = mxCreateString("Matrix dimensions must agree."); return;

  }

  if ((Aclass == INTerval) && (Bclass == INTerval))
  {
    Arows = mxGetM(prhs[1])/2;
    Acols = mxGetN(prhs[1]);
    Brows = mxGetM(prhs[3])/2;
    Bcols = mxGetN(prhs[3]);

    if (Acols == Brows)
    {

      pA = (BIASINTERVAL *) mxGetPr(prhs[1]);
      pB = (BIASINTERVAL *) mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Arows * 2, Bcols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulMIMI(pR, pB, pA, Bcols, Brows, Arows);

      return;
    }

    if ((Acols == 1) && (Arows == 1))
    {

      pA = (BIASINTERVAL *) mxGetPr(prhs[1]);
      pB = (BIASINTERVAL *) mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Brows * 2, Bcols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulIMI(pR, pA, pB, Bcols, Brows);

      return;
    }

    if ((Bcols == 1) && (Brows == 1))
    {

      pA = (BIASINTERVAL *) mxGetPr(prhs[1]);
      pB = (BIASINTERVAL *) mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Arows * 2, Acols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulIMI(pR, pB, pA, Acols, Arows);

      return;
    }

    plhs[0] = mxCreateString("Matrix dimensions must agree."); return;

  }

  if ((Aclass == INTerval) && (Bclass == DouBLe))
  {
    Arows = mxGetM(prhs[1])/2;
    Acols = mxGetN(prhs[1]);
    Brows = mxGetM(prhs[3]);
    Bcols = mxGetN(prhs[3]);

    if (Acols == Brows)
    {

      pA = (BIASINTERVAL *) mxGetPr(prhs[1]);
      pb =                  mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Arows * 2, Bcols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulMRMI(pR, pb, pA, Bcols, Brows, Arows);

      return;
    }
    if ((Acols == 1) && (Arows == 1))
    {

      pA = (BIASINTERVAL *) mxGetPr(prhs[1]);
      pb =                  mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Brows * 2, Bcols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulIMR(pR, pA, pb, Bcols, Brows);

      return;
    }

    if ((Bcols == 1) && (Brows == 1))
    {

      pA = (BIASINTERVAL *) mxGetPr(prhs[1]);
      pb =                  mxGetPr(prhs[3]);

      plhs[0] = mxCreateDoubleMatrix(Arows * 2, Acols, mxREAL);
      pR = (BIASINTERVAL *) mxGetPr(plhs[0]);

      BiasMulRMI(pR, pb, pA, Acols, Arows);

      return;
    }

    plhs[0] = mxCreateString("Matrix dimensions must agree."); return;

  }

  mexErrMsgTxt("Unknown class or too few arguments."); return;

} /* mexFunction */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -