zoukankan      html  css  js  c++  java
  • VC调用MATLAB.

    利用Matlab引擎
    Matlab引擎采用客户和服务器计算方式,在运用中,Vc的C语言或C++语言的程序作为前端客户机,它向Matlab引擎传递命令和数据信息,并从Matlab引擎接收数据信息,它提供了下列几个函数: engOpen, engGetArray, engPutArray, engEvaString,

    engOutputBuffer ,engClose与客户机进行交互。

    下面例程是在Vc下建一个基于对话框的应用程序,在对话框中设置一个Button控件OnMatlabEngine.,在对话框 .cpp文件中加入”engine.h” 和“math.h” 头文件,下面给出部分程序清单。

    Void CtestmatlabDlg::OnMatlabEngine(){

    Engine *ep;

    mxArray* T=NULL,*result=NULL,*mFs=NULL,*mnfft= NULL;

    double datax[1024];

    char buffer[1024];

    for(int j=0;j<1024;j++)//注:如通过采集卡采集数据可将采集的数据放在datax[]数组中,此循环就不需要

    {

    double samt=(double)(1.0/1024);

    datax[j]=sin(2.0*63.0*samt*3.1415926+1.15*3.1415926);

    }

    double *pPxx,*pFxx;

    if(!(ep=engOpen(" \0"))){//打开Matlab引擎,建立与本地Matlab的连接

    fprintf(stderr,"\n Can't start MATLAB engine\n");

    exit(-1);

    }

    double Fs[1]={1024};//因为Matlab所有参与运算的参数都是矩阵的形式,因而下列几行将参数转变

    double nfft[1]={1024};//成Matlab可接受的矩阵形式。

    T=mxCreateDoubleMatrix(1,1024,mxREAL);

    mnfft=mxCreateDoubleMatrix(1,1,mxREAL);

    mFs=mxCreateDoubleMatrix(1,1,mxREAL);

    mxSetName(T,"T");

    mxSetName(mnfft,"mnfft");

    mxSetName(mFs,"mFs");

    memcpy((char*)mxGetPr(T),(char*)datax, 1024*sizeof(double));

    memcpy((char*)mxGetPr(mnfft),(char*)nfft, sizeof(double));

    memcpy((char*)mxGetPr(mFs),(char*)Fs,1*sizeof(double));

    engPutArray(ep,T); //将转化的参数放入引擎中,此时可在Matlab command窗口下查看此参数

    engPutArray(ep,mnfft);

    engPutArray(ep,mFs);

    engEvalString(ep,"[pxx,fo]=psd(T,mnfft,mFs);"); //利用引擎执行工具箱中文件

    engOutputBuffer(ep,buffer,512); //如只想看显示图形,可将返回参数去掉,psd无返回参数缺省情况下会自动画图形

    result=engGetArray(ep,"pxx");//取出引擎中的数据放在所指的区域中供后续处理

    pPxx=mxGetPr(result);

    result=engGetArray(ep,"fo");

    pFxx=mxGetPr(result);

    engEvalString(ep,"plot(fo,10*log10(pxx));");//利用引擎画图

    engEvalString(ep,"title('功率谱分析');");

    engEvalString(ep,"xlabel('Hz');");

    engEvalString(ep,"ylable('db');");

    mxDestroyArray(T); //释放内存

    mxDestroyArray(mFs);

    mxDestroyArray(mnfft);

    mxDestroyArray(result);

    engEvalString(ep,"close;");

    engClose(ep);

    }

    上述

  • 相关阅读:
    使用Chrome开发者工具研究JavaScript的垃圾回收机制
    Java JDK目录下的jmap和jhat工具的使用方式
    Java注解@Cacheable的工作原理
    使用Java JUnit框架里的@Rule注解的用法举例
    使用Java JUnit框架里的@SuiteClasses注解管理测试用例
    Java JUnit框架里@Category注解的工作原理
    使用SAP CRM mock框架进行单元测试的设计
    将ABAP透明表的定义(元数据)解析出来导入到剪切板(clipboard)里
    SAP ABAP Netweaver里的胖接口(fat interface)
    关于STM32的FLASH操作【转载】
  • 原文地址:https://www.cnblogs.com/wqj1212/p/1020351.html
Copyright © 2011-2022 走看看