m文件转换为cc文件的编译绘图参数打包问题总结

m文件转换为cc文件的编译绘图参数打包问题总结

ID:8847902

大小:121.50 KB

页数:9页

时间:2018-04-09

m文件转换为cc文件的编译绘图参数打包问题总结_第1页
m文件转换为cc文件的编译绘图参数打包问题总结_第2页
m文件转换为cc文件的编译绘图参数打包问题总结_第3页
m文件转换为cc文件的编译绘图参数打包问题总结_第4页
m文件转换为cc文件的编译绘图参数打包问题总结_第5页
资源描述:

《m文件转换为cc文件的编译绘图参数打包问题总结》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、m文件转换为C/C++文件的编译、绘图、参数、打包问题总结在工程计算相关项目中,常常利用Matlab来完成计算、算法、绘图等功能。使用Matlab来完成这些功能非常简单,Matlab提供的m编程语言功能强大,代码量少。为了在自己的C/C++项目中加入这些功能,需要一系列繁琐的过程,令很多人望之却步。主要的困难在于:l         如何从m文件生成VC可用的C/C++代码;l         如何设置编译参数,在VC中编译这些代码;l         如何在C/C++语言中设置输入输出参数,使之与M代码生成的C++代码一同运行;l 

2、        如何制作包含matlab运行时库的安装程序。下面结合网络上面的资料,对以上问题进行了总结,较好的解决了上面的问题。我使用的相关开发环境如下:Matlaba6.5;VC6;WindowsXP。11       引子进入正文之前,要说说写这篇文章的起因。近几天发现一个半年前写的程序出现了莫名其妙的bug。在程序退出时总有一个线程死掉不能退出,导致整个进程不能正常退出,必须从进程管理器中杀掉。由于该程序一共有7个子线程,我一个个检查后发现程序在运行时有一个并非由我创建的多余子线程。通过ProcessViewer和Spy++等

3、工具观察发现,该线程中有以下几个窗口IME、TthreadWindow和MSCTFIMEUI,查来查去毫无头绪。首先怀疑是多线程库有bug,因此仔细重读了一遍自己封装的多线库,还真的发现了几个bug,但是修正后于事无补。花费了三天时间;然后怀疑是界面库有问题,仔细比较了使用界面库和不使用界面库前后的差别发现界面库会多启动两个界面管理线程,但是都会正常退出,没有问题。花费一天时间;最后只好怀疑是引入的dll启动了某个线程。一个个排查dll,终于发现了ago4501.dll和v4501v.dll这两个可疑的dll。这两个dll是由Mide

4、va(将m文件转换为C/C++代码的一个中间工具)引入的。当初使用Mideva就是因为在直接使用matlab的mcc出现了困难,不得已找mideva代替。很多人还信誓旦旦的说Mideva是最适宜VC使用的m代码转换工具。很多书和网络资料都还给出了示例代码,我就不相信他们没有碰到这个线程问题,只是避而不谈罢了。想起Mideva已经被MathWork公司收购并且不再支持了,我就决心放弃mideva,继续使用mcc来生成代码。所有的历程都记录如下。22       M文件转换为C/C++文件要在VC中使用m文件,方法有很多种。最简单的我认为

5、还是使用Mideva,当然如果你能够搞定那个线程问题,并且永远只使用matlab6以前的版本,你就可以使用mideva。这里就不介绍了。第二种就是使用Matlab引擎来调用m文件,也比较简单,但是你必须在目标机器上安装matlab才行,这往往是不现实的。第三种使用mcc将m文件编译成为C/C++代码,然后导入Vc编译,因为常常生成很多源代码,使用很繁琐,这个很多网络资料已经说过。第四种就是使用mcc将m文件编译为头文件、dll和lib然后导入VC编译。目前这是最可行的一种方法。本文引用了首发于哈工大紫丁香站BBS的fork(撒哈拉沙漠

6、的沙)写的解决方法。并做了一些文字上的修改。Fork的例子有些简单,没有涉及多维数据参数的构建与输入,也没有多字符串组参数的构建,因此我重写了一个较为实用的例子来展示他的内容。12.1             例子例子的内容是通过输入的数据来展示农作物产量的统计图,其m代码如下:functionresult=MyStat(mStatMatrix,mNameMatrix,n)% 画出柱状图来展示各个不同季度的农作物产量%mStatMatrix代表农作物产量矩阵,每行为一个地区,每行第一列为小麦产量,第二列为玉米产量;%mNameMatr

7、ix代表地区名称字符串数组;%n代表地区个数% 返回值为所有地区粮食总产量bar(mStatMatrix);xlabel('地区名称');ylabel('产量');title('农作物产量统计');legend('小麦','玉米',1);totalnum=0;fori=1:n text(i,max(mStatMatrix(i,1),mStatMatrix(i,2))+0.25,mNameMatrix(i)); totalnum=totalnum+mStatMatrix(i,1)+mStatMatrix(i,2);endset(gcf,

8、'Menubar','none');result=totalnum;在matlab中输入如下命令:data=[1,2;3,4;5,6;1,1]name={'1号地区','15号地区','7号地区','9号地区'}n=4M

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。