标题:Matlab 与 C++ 混合编程
只看楼主
vfdff
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:2172
专家分:425
注 册:2005-7-15
结帖率:79.17%
 问题点数:0 回复次数:2 
Matlab 与 C++ 混合编程
Matlab 与 C++ 混合编程      
   Matlab是当今世界上使用最为广泛的数学软件,它具有相当强大的数值计算、 数据处理、系统分析、图形显示,甚至符号运算功能,是一个完整的数学平台,在这个平台上,你只需寥寥数语就可以完成十分复杂的功能,大大提高了工程分析计算的效率。另外由于Matlab的广泛使用,于是出现了为各个领域专门使用的工具箱(即在某一研究领域常用数学工具的函数包),这些工具箱的出现更加促进了Matlab的流行。   
  Matlab强大的功能只能在它所提供的平台上才能使用,也就是说,你必需在安装有matlab系统的机器上使用.m文件,这样就给工程计算带来了很大不便;特 别是,在matlab中,使用的行解释方式执行代码,这样大大地限制了代码执行速度。 于是人们想到,能否开发一个matlab与其他高级语言的接口,这样就可以把matlab 的强大功能融入各种应用程序中,并且通过高级语言编译器编译为2进制代码, 从而大大提高了执行速度。   
  于是matlab的5.1版本提供了自带的C++ Complier,同时MathTools公司也为 Matlab开发了m文件高效解释和调试IDE:MIDEVA。经过近两年的发展,matlab 5.3 中的C complier--mcc版本已经为2.0,而MIDEVA最新版本为4.5。   
  将matlab与C混合编程大概有如下三种方法:   
用Matlab的mcc将.m文件翻译为cpp源文件,然后在C编译器中调用 也可以用mcc编译编译为stand-alone程序。     
用Matcom(MIDEVA)将.m文件翻译为cpp代码,并编译为exe或dll 文件。   
按照matcom的语法,在VC或BCB中直接书写matlab语句(与matlab 很相似),这也是我最喜欢用的方法。   
  方法1和2/3各有利弊,1不支持图形(支持图形的库国内现在还没有D), 1对类支持也不够,2支持绝大多数的matlab语句(包括图形),但对于struct等的支持也有缺陷。   
   MATLAB5.3的提供了C/C++数学库,其中的C++数学库功能很强,使用它可以用类似MATLAB 的语法编写C++程序,十分方便。虽然速度上仍然比手工C/C++程序慢,但是由此换来的高效的开发效率和可靠性往往是值得的。另外mcc命令可以将M文件转化为C或CPP文件,编译后可以脱离MATLAB运行 ,它们也是使用的C/C++数学库。 不过,MATLAB的数学库在开发时似乎倾向于编译独立的可执行程序,把VC、BC只是作为一个编译和连接的工具,而没有过多地考虑在VC、BC的集成环境下进行开发。这给我们带来了不便。 很多网友问起如何将MCC生成的C++程序嵌入到VC。最近对这个问题做了一下尝试,在这里做一个总结,请大家回去试试。这里只介绍VC的情况,用BC的网友就自己研究研究吧估计是类似的。   
1、设置项目编译选项 首先建立一个新的项目,或者打开一个已有的项目,然后选择菜单
Project->Settings->C/C++
Category:Preprocessor
Preprocessor definitions:
添加: MSVC,IBMPC,MSWIND
Category: Precompiled Headers
选择: Automatic use of precompiled headers
Through header: stdafx.h     
2、调设置项目连接选项
首先要从下面几个函数定义文件(*.def)生成相应的导入库文件(*.lib)
libmmfile.def
libmcc.def
libmatlb.def
libmx.def
libmat.def
它们位于目录c:\matlab\extern\include
用下面命令导出库文件:
lib /def:libmmfile.def /out:libmmfile.lib /machine:ix86
lib /def:libmcc.def /out:libmcc.lib /machine:ix86
lib /def:libmatlb.def /out:libmatlb.lib /machine:ix86
lib /def:libmx.def /out:libmx.lib /machine:ix86
lib /def:libmat.def /out:libmat.lib /machine:ix86
将它们放入你的项目连接选项
Project->Settings->Link
Category:Input
Object/library modules:
添加:libmatpm.lib libmmfile.lib libmcc.lib libmatlb.lib libmx.lib libmat.lib
注1: 中间是空格,不要加逗号
注2: libmatpm.lib是C++ MathLib的库,如果是只用C,就不用连接它了。
Ignore libraries:
添加: msvcrt.lib 注:
仅在Debug版本中需要。原因不明.     
3、设置编译环境
Tools->Options->Directories
Include fiels添加:
c:\matlab\extern\include
c:\matlab\extern\include\cpp
Library fiels添加:
c:\matlab\extern\lib
c:\matlab\extern\include
注:下面这个目录是那些lib所在的地方。 如果都挪到上面的目录,这个自然就不要了。     
4、编写程序
用MCC命令生成的CPP文件和自己手工编写的CPP文件, 其项目设置是完全相同的, 程序的语法原则上也是一样的. 只是MCC生成的CPP文件有大量"没用"的代码.
(1)添加自己编写的程序模块
用下面文件头:
#include "stdafx.h"
#include "matlab.hpp"
然后, 按照C++ MathLib文档要求的格式书写程序.
(2)嵌入mcc生成的文件 在MATLAB下用下面格式的命令生成cpp文件 mcc -t -L Cpp test 得到test.hpp, test.cpp 将test.cpp加入项目, 不做任何改动. 最后,摁F7编译就可以了。     
5、实例
上面罗罗嗦嗦一大堆,肯定让你打哈欠了:没关系,其实还是挺简单的,这里有个VC的project,用C++数学库解决了一个幼儿园的算术题. 这里说明一下:
MATLAB程序test.m:
function [sum, prod]=test(x,y)
sum = x+y;
prod = x*y;
用来计算两个数的和与积。注意这是两个返回变量的情况。 另外,x,y当然可以是数组。 用mcc命令生成了test.hpp和test.cpp。
文件demo.cpp:
#include "stdafx.h"
#include "matlab.hpp"
#include "test.hpp"
void mccDemo()
{ CString str;
mwArray x, y, sum, prod;
double dx,dy,dsum,dprod;
x = 5.0;
y = 10.0;
sum = test(&prod, x, y);
dx=x(1,1);
dy=y(1,1);
dsum=sum(1,1);
dprod=prod(1,1);
str.Format("%f+%f=%f\n%f*%f=%f", dx,dy,dsum,dx,dy,dprod);
AfxMessageBox(str); }   
  由于采用了C++数学库,语法很简单。注意数组的赋值、其中数据的存取,这些都要仔细地看手册。 最后是跳出一个消息框,显示计算结果。  

但是我不能在 matlab\extern\include 中找到需要的五个文件

缺文件.JPG (88.45 KB)
搜索更多相关主题的帖子: Matlab 混合编程 
2008-12-04 22:00
vfdff
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:2172
专家分:425
注 册:2005-7-15
得分:0 
matlab与vc混合编程心得(matcom)
1. 什么是Matcom?
Matcom是MathTools公司(UPenn)开发的一个基于C++矩阵函数库Matrix的一个matlab m文件与cpp文件的转换程序。MIDEVA为他的一个集成调试编译环境(界面)。
Matcom独立于matlab之外,但需要外部的c++编译器,在安装时需要指定,否则无法工作。安装的时候需要指定matlab的位置主要是为了编译文件中需要的一些系统函数来找到路径用的。
现在MathTools公司已经被生产Matlab的MathWorks公司兼并,Matcom最后版本为4.5,之后部分matcom的内容被合并到mathworks的visual matlab中。
2. 如何在VC或C++Builder中使用matcom数学库?
1).在Project\Add to project\选择\lib\v4500.lib或在工程设置中指定其路径。
2).文件头写#include "matlib.h" 然后就可以用了。
3. 如何取出matcom矩阵的元素的值并交给C语言变量?
例:
double mydata[3][3];
dMm(amatrix);
amatrix=rand(3);
for(int i=1;i<;=3;i++)
for(int j=1;j<;=3;j++)
mydata[i-1][j-1]=amatrix.r(i,j);
//or mydata[i-1][j-1]=amatrix.fastindex(i,j);
也可以用memcpy() 把amatrix.pr指针的内容读出来,交给mydata,但行列需要转置。




4. Matcom在C++中应该怎么调用?
下面是一些常用的算术运算符在C++中函数表,对于多个输出的函数的使用,i_o作为分割符meshgrid(colon(0.0,1.0),colon(0.0,1.0),i_o,xi,yi);
与matlab中的[xi,yi]=meshgrid(0:1,0:1);是等价的。


5. 如何将C语言变量转换为Mm?
仍然使用Mm的.r()函数或者.fastindex()函数,在本节2)中的例子中把赋值语句左右两侧互换即可。A.r(i,j)=(double)mydata[j][i];

前面是转贴人家的心得。
写一些自己的心得。这里用的是visual matcom。安装方法:

6、直接在VC环境下使用科学运算库,即Matcom的Matrix<LIB>,它是按照Matcom的语法在VC中实现类似于Matlab函数的方法。但是这里还有一种将Matcom集成到VC环境的方法,即安装Visual Matcom的方式,这种方式操作更加简便易行,只需要熟悉Matlab编程,经过简单的步骤就可以轻松实现VC环境中调用Matlab。下面介绍Visual Matcom开发环境的安装。
(1)拷贝<matcom45>\bin\usertype.dat文件(<matcom45>指Matcom的安装路径)到<visual c++>\Common\MSDev98\Bin目录(<visual c++>指VC的安装路径)下。
(2)运行Visual C++,从菜单条中选择Tools/Customize/Add-ins and Macro Files,选择Browse,改变文件类型为Add-ins(.dll),选定<matcom45>\bin\mvcide.dll文件,确定。
(3)这样,可以在Visual C++的开发环境中看到一个如图1所示的Visual Matcom工具栏,表明安装成功。




7、vc中调用malib库德格式:initM(MATCOM_VERSIONT);//声明matlib库
exitM();//退出matlib库


添加一点其它地方找到的:
>*****************************************************************************<
> 第四节:Matcom的常见问题
>*****************************************************************************<

===================================

2)如何取出matcom矩阵的元素的值并交给C语言变量?
:#FangQ(Qianqian.Fang@Dartmouth.Edu), 1999/11/2. SMTH/MathTools#

double mydata[3][3];
dMm(amatrix);
amatrix=rand(3);
for(int i=1;i<=3;i++)
for(int j=1;j<=3;j++)
mydata[i-1][j-1]=amatrix.r(i,j);
//or mydata[i-1][j-1]=amatrix.fastindex(i,j);

也可以用memcpy() 把amatrix.pr指针的内容读出来,交给mydata,但行
列可能要转置。

如果amatrix=sparse(…),用amatrix.r()方法不能取出需要的值


3)Matcom中有多个输出的函数在C++中应该怎么调用?
:#FangQ(Qianqian.Fang@Dartmouth.Edu), 1999/11/2. SMTH/MathTools#

使用i_o作为分割符
meshgrid(colon(0.0,1.0),colon(0.0,1.0),i_o,xi,yi);
与matlab中的
[xi,yi]=meshgrid(0:1,0:1);

是等价的

4)如何在VC或C++Builder中使用matcom数学库?
:#FangQ(Qianqian.Fang@Dartmouth.Edu), 1999/11/2. SMTH/MathTools#

1.在Project\Add to project\选择\lib\v4500.lib
2.文件头写#include "matlib.h"
然后就可以用了


5)使用了matcom4.5数学库的VC/C++Builder程序如何发布?
:#FangQ(Qianqian.Fang@Dartmouth.Edu), 1999/11/2. SMTH/MathTools#

在VC/CB中调用了matcom库,通过编译生成独立执行的程序,所以,
不需要matlab系统,但一些必要的dll文件还是需要的,这
些dll在window\system\下面,(在4.5版本中)大概
有ago4500.dll,v4500v.dll,opengl32.dll,glu32.dll等
四个文件

6)安装matcom在搜索matlab路径时说找不到matcom.m,怎么办?
:#FangQ(Qianqian.Fang@Dartmouth.Edu), 2002/6/22. SMTH/MathTools#

原因是matlab 6.x的Windows版本matlab.exe不在matlab\bin下,而
在matlab\bin\win32,所以,在安装matcom时,把bin\win32\matlab.exe
移动到bin\,即上移一层目录,安装matcom后,再移动回去就可以了。

其实是否安装有matlab对matcom没有什么影响,你完全可以选择没有
安装matlab,仍然可以编译大多数文件。需要matlab\toolbox下的文件
时,用addpath()添加路径或者拷贝到当前目录下就可以了。


7)使用MIDEVA在编译有些工具箱和simulink的程序时出错,请
问是什么原因?
:# techsoft (SoftMAN), 2000/4/2.SMTH/MathTools#

目前MIDEVA/MATCOM仅是纯.M文件的开发平台(通俗地说
是MATLAB的替代物),但MATLAB外,还有SIMULINK/STATEFLOW
及其它TOOLBOX/BLOCKSET对于MIDEVA/MATCOM来说无
法COMPILER,因为MIDEVA/MATCOM是JIT机制,它不能访
问MATLAB的其它工具包尤其是它们的DLL库。要是其它工具包都是
纯文本的.M文件那该多好啊!不过可用出自MATHWORKS的MATLAB
COMPILER。

~~~~~~~~~~~~~~~好好学习~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2008-12-05 15:02
vfdff
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:2172
专家分:425
注 册:2005-7-15
得分:0 
Visual C++与Matlab混合编程方法在图像处理中的应用
1 引言 LUPA开源社区5x5y3p*u-U.T$ZMA
Matlab 是美国Mathworks公司于20世纪80年代中期推出的一套数值计算软件,可以实现数值分析、矩阵运算、自动控制、信号处理和图像处理等若干领域的计算和图形显示功能。它不仅包含大量高度集成的函数可供直接调用以解决各种复杂的计算,而且提供了简洁的人机界面、丰富的图形用户界面GUI(Graphical User Interfaces)开发功能以及求解特定学科问题的求解工具箱ToolBox。与此同时编写程序Matlab所需时间往往能比使用其他编程语言缩短许多倍。自面世以来,Matlab在教学和科研等领域受到了广泛的重视和应用, 在解决复杂的数学计算和新算法的研究中具有极大的优势。
G ^[H,~+bj$K.iY#B01.1 软件的特点归纳 [4]LUPA开源社区)CrBMd q&eR Se1f B
(1) 易学易用性 LUPA开源社区 j Z J\W L/M-k
Matlab是一门编程语言,其语法规则和C语言大同小异,因而具有一般编程语言基础的用户很快就可以掌握。 LUPA开源社区'A;LS"gO6Yt9Q
(2) 代码短小高效 LUPA开源社区RoiXr$aN-r
Matlab将不同数学分支的算法以函数的形式分类成库,使用时直接调用这些函数并赋予实际参数就可以解决问题,快速而准确。
`sb)N.hn[ Y0(3) 计算功能强大 LUPA开源社区Hi1AJ6q,P xt
该软件具有强大的矩阵计算功能,除了一般的加、减、乘、除、转置和求逆运算外,还非常适合处理稀疏矩阵等特殊矩阵运算以及有限元等大型数值算法的编程。 LUPA开源社区+]-z.\O0Lg\M e}
(4) 可扩展性能
li7k'[!DC$}m0Matlab最重要的特点是易于扩展,它允许用户自行编写指定功能的m文件,组成自己的工具箱。当前支持Matlab的商用ToolBox(工具箱)有数百种之多。Matlab支持DDE和ActiveX自动化等机制,可以与同样支持该技术的应用程序接口。利用m文件或MEX文件可以实现也VB、VC等程序的进程内无缝集成;利用web服务器,可实现Matlab与网络程序的接口;利用API函数,还可以实现Matlab与硬件的接口。
2^r Id]Tc7|O01.2 Matlab 自身所存在的某些不足也限制了它的应用范围
9P*r:[.U#U6Y0(1) Matlab 是一种解释性语言,所以它的代码执行速度慢,这对于实时性要求较高的领域,如自动控制、信号处理等,其实时效率是较差的。
\M]"kU _5w6v0(2) Matlab 程序不能脱离其环境运行,其功能只能在它本身所提供的平台上使用,因而不能被用于开发商用软件。
~ j.Py#So"?\0(3) Matlab 程序可被直接看到源代码,因而算法和数据的保密性欠佳。 LUPA开源社区 T2To(g'Nk]r
Visual C++( 以下简称VC)是Microsoft公司推出的强大的可视化集成编程环境, 从底层软件到上层直接面向用户的软件都可以用VC开发, 而且强大的调试功能也为大型复杂软件的开发提供了高效的排错手段。使用VC开发的系统具有界面友好、代码效率高和执行速度快等一系列优点. 同时C++语言支持面向对象的程序设计, 而利用面向对象方法设计的软件具有良好的可重用性、可维护性和可扩充性等特点。它是目前综合性最高、最强大、也是最复杂的软件开发工具之一, 应用极为广泛。
k~6ei't3b0因此实现VC与Matlab混合编程,使两者结合起来,协同工作,将大大减少编程的工作量、提高程序执行效率。利用VC这一优秀编程工具可以弥补Matlab在处理具体问题时的缺陷,利用Matlab的强大数值运算等功能则可以增强VC对信号处理、三维处理、自动控制等方面的能力。两者结合将会充分发挥各自的优势,必将提高软件开发效率,使开发的软件具有更高的性能,更广阔的应用领域。LUPA开源社区h)`l1Q^E l,uH
2 VC++ 与Matlab的接口技术简介
Rz4UV1s*c(|%`02.1 在VC环境中调用Matlab程序主要方法
G H(d0t7hwE]0为将Matlab的强大功能融入到各种应用程序中,通过高级语言编译器将Matlab的m文件编译为二进制代码已成为研究热点。
e+_2f.vH(MI2o._0(1) 在VC中启用MATLAB EN GINE(引擎),采用客户机/服务器(Client/Server)的计算模式。这种方式需要Matlab在后台运行,离不开Matlab环境。但是它可以调用Matlab工具箱函数和图形函数。
$b,}f,Mnj g;D$c0(2) 利用MATLAB COMPIL ER(编译器),将Matlab 的函数编译成脱离Matlab环境的可执行程序(.exe文件), 在VC中调用。
$Z0X i y^6K0(3) 利用Matlab的数学函数和图形库。6.1版本的Matlab软件包中提供了C/C++的数学函数和图形库,通过其编译器可以将Matlab中编写的m文件转换成以C/C++代码的文件,而且可以将m文件生成dll库,甚至可以直接调用其库函数,生成不依赖Matlab的可执行文件。 LUPA开源社区-z-?BLD
(4) MIDEVA(Matcom) 是第一个由Matlab到C++的编译开发软件平台.使用Matcom编译器可以将Matlab源代码译成同等功能的C++代码,并编译为EXE或DLL文件。既保持了Matlab的优良算法,又提高了执行速度。它还支持一定的图形显示,生成代码的可读性很好。因其简单便捷、功能强大、应用灵活,本文采用这种实现方案。
E N ]&of3zZJ5fA03 Matcom 在图像处理程序中的具体使用方法和技巧
3S Wb_5`Ov0下面以实现图像处理中绘制直方图和快速傅立叶变换的编程过程为例,介绍通过Matcom实现VC对Matlab程序的调用过程,运行环境为:WindowsXP、Matlab6.5、Matcom4.5、Visual C++6.0。     LUPA开源社区tc6Ea vwYt3g1S
3.1 编译环境设置 [2]    LUPA开源社区)n6C@6~6g&Si:H
首先安装MIDEVA,然后运行Visual C++6.0,从菜单条中选择Tools/Customize/Add-ins and Macro Files,在出现的对话框中选中Visual Matcom Add-in,关闭对话框,这时在Visual C++[1]的开发环境中看到一个Visual Matcom工具栏,表明安装成功。LUPA开源社区+Dv;Kxpz1?.q i
3.2 代码编写 LUPA开源社区.g3xh|Ub:f/oX!V
在MATCOM或者Matlab环境中编写实现绘制图像直方图的文件myhist.m代码如下 :
8hOU/N$UY4eXF0function h=myhist(x) %绘制灰度图像的直方图 LUPA开源社区2l S itV+{3N9Vs,C0b(H
h=zeros(1,256);[m,n]=size(x)LUPA开源社区\oIB"fe+JJ[2G
for i=1:mLUPA开源社区`V$U"RA6N!hT0HE5Q
for j=1:nLUPA开源社区!gP0g9Rv
h(1,x(i,j)+1)=h(1,x(i,j)+1)+1;
%S~:N*s`*~0endLUPA开源社区"u1b5L\L;Ck
endLUPA开源社区F;eD4U[@
plot(0:255,h)LUPA开源社区w O~#[Tc{)GH I
建立一个新的VC++工程或者使用现有的图像处理的MFC工程Dip.dsw,用C++实现DIB图像的读取,获取图像相关信息,图像显示,保存等基本功能[3]。再建立一个用于图像频域处理的类CFreqPro,将来在此类中添加有关频域处理的成员函数。点击Visual Matcom工具栏上的m++图标,选择保存过的Matlab文件myhist.m进行转化。这时会在VC中出现一个转换完毕的说明文件,文件中如果报告有错误,可以双击C++files文件夹下的myhist.m直接进行修改,不必回到Matlab环境,再重新转化直到没有错误报告为止。在需要使用myhist()函数的文件中添加头文件matlib.h和myhist.h,加入代码#include”matlib.h”,#include”myhist.h”。
L;l!x_!nM.dN0在调用matcom的Matrix<LIB> C++库函数之前用initM(MATCOM_VERSION)初始化类库调用,并用exitM()结束对类库的调用。在MFC工程文件中,一般是在一个类(例如CDipDoc)的构造函数中添加initM(MATCOM_VERSION)以完成类库的初始化工作,在该类的析构函数中调用exitM()结束对类库的调用。 LUPA开源社区#f/ZL*T]6Rd
3.3 创建图像数据矩阵和将数据矩阵赋给图像数据区的功能核心代码
'X.]k BW W7\!Bd0在matcom中,提供了一个双精度Matrix类型-Mm,因为所有的操作均为矩阵运算。为利用矩阵运算完成图像变换,首先应将其图像数据赋给矩阵变量,而且能将运算后的矩阵变量再回赋到图像数据区[5]。为此,在CFreqPro中添加成员函数GetMatData()和SetMatData(),分别实现创建图像数据矩阵和将数据矩阵赋给图像数据区的功能。这两个函数对常用的8位灰度图像处理具有较好的通用性和参考价值。核心代码如下(有删节 ):
Ud4\CDAf0Mm CFreqPro::GetMatData()
PD9Lf!~[0v-H aBF0{ DWORD SizeImage = nWidth * nHeight;
9g&i&?V U;K4?0//创建图像数据矩阵,并将其元素初始值设为 0
[#Th4u%kI1o0m_matBits = zeros(1, SizeImage);LUPA开源社区q$H'uHuvq
//默认的矩阵数据类型是double,首先将其转换为unsigned char型 LUPA开源社区fs xT(^$w
// 以便用memcpy内存拷贝命令将图像数据赋给矩阵。 LUPA开源社区,xy{ T5xl7^
m_matBits = muint8(m_matBits);LUPA开源社区%`5Pun)f5[
// 通过Matrix<LIB>C++库的.addr()函数返回矩阵变量的内存指针,完成对矩阵单元的访问 LUPA开源社区 J`{F2cY
// 用memcpy内存拷贝命令将图像数据赋给矩阵。 LUPA开源社区(oLQY"A
memcpy(m_matBits.addr(), pBits, SizeImage);LUPA开源社区-~E&q1Ta1or
// 由于Mm类型的矩阵是按先列后行的顺序排列, LUPA开源社区"N6tCu:X0oX,t.j!O
// 在此用reshape()函数将创建的一维矩阵m_matBits变为nWidth×nHeight的二维矩阵。
bbNbX1|N0// 再用rot90()函数将二维矩阵逆时针旋转90度,将矩阵变为nHeight×nWidth的二维矩阵,
Q"mTk e0vfz0// 并使矩阵的第nHeight行对应图像数据的第一行数据。 LUPA开源社区7kyVa(tg
m_matBits = rot90(reshape(m_matBits, nWidthBytes, nHeight));
6ll*hBd0// 将矩阵由unsigned char型转换为double型,以便进行运算 LUPA开源社区Hh%o)XH
m_matBits = mdouble(m_matBits);
a.Q v%dl0}LUPA开源社区)@:b']"k!p
///////////////////////////////////LUPA开源社区Vg mA8H d?
BOOL SetMatData() LUPA开源社区*x!s$yEG4U0i0p:O
{ // 将矩阵数据范围限定于(0— 255)
5ZDS Co6Y`0~7V"b0m_matBits = mabs(m_matBits);LUPA开源社区,}2r&z_ @ L[[Gs3R
Mm L = m_matBits > 255.0;
6S!W$Tn9UwF;D0Mm NotL = !L;LUPA开源社区b-] p'BQ:^I
m_matBits = times(m_matBits, NotL) + L * 255.0;
iBc |O2olN0//将矩阵由double型转换为unsigned char型,以便将图像数据赋给矩阵
WM%P&B];v&P7K([0m_matBits = muint8(m_matBits);LUPA开源社区`*T7^+N]5k
// 对矩阵进行转置操作 LUPA开源社区 H4jmA^ e
m_matBits = rot90(m_matBits, -1);
_(Fk [1C0// 将图像数据赋给矩阵 LUPA开源社区WIbiX'WT
memcpy(pBits, m_matBits.addr(), (nWidth * nHeight)*sizeof(unsigned char));
YR#d4HM-H0return( TRUE );}
:C5E-D;Im5d7TeaU M-BW]03.4 图像的傅立叶变换和绘制直方图函数
l jpOA9h:}0图像数据矩阵建立后,就可以利用Matrix<Lib>C++库函数通过各种矩阵运算完成图像变换的工作。下面的函数仅实现图像的傅立叶变换和绘制直方图,用同样方法,离散余弦变换、离散沃尔什-哈达玛变换也都能实现。在图像频域处理类CFreqPro中添加成员函数 FFT2()
+fo^{-r }7S0Mm CFreqPro::FFT2(CDib *pDibObject)LUPA开源社区2C@/cC2v Dbj$M
{if( pDib!= NULL ) m_pDib = pDib;
H*r)^Tdqp7T!r0//创建图像数据矩阵 LUPA开源社区|9Pd]$f+r4Kv8B
GetMatData();
*Z'gOtLGiB9A0// 获得矩阵的行数和列数 LUPA开源社区D6v*NM1U
Mm mSize = size(m_matBits);LUPA开源社区B _ K&yo5p
// 调用Matrix<Lib>C++库函数fft2()完成二维离散傅立叶变换 LUPA开源社区D!_u~2D8v5Y9} pC%U
Mm ff = fft2(m_matBits);
%jHw p j+eT0Mm matTransed = ff;LUPA开源社区ss$v+@S6x6qj
// 调用Matrix<Lib>C++库函数fftshift()将频域中心移到矩阵中心 LUPA开源社区k(Js],S4e [2l]
ff = fftshift(ff);
8X Xj vv{0// 调用Matrix<Lib>C++库函数mabs()计算频谱 LUPA开源社区5@?Y)G6\9dQv
m_matBits = mabs(ff) / sqrt(mSize.r(1,1)*mSize.r(1,2));LUPA开源社区 s9}&fR3]8@%bXw$Q
// 绘制直方图
uwk:QMw0myhist(m_matBits);
R%n*H:Mr:T]0P0// 将矩阵数据赋给图像数据区 LUPA开源社区Fo8_B%[i f X0Y~k
SetMatData();LUPA开源社区_j FgR!D
return matTransed;}
"d!QM @ y v0运用本方法对一8位灰度图像(如图2)进行了离散傅立叶变换,结果如图3所示,利用myhist()函数实现直方图绘制。
+FJ U,kP D;r04 结束语
:tc5YJ:Dl r+Xi0在图像处理程序中,既可以直接调用调用Matrix<Lib>C++库函数,也可以在VC环境中转换.m函数文件。如果需要转换的.m文件不是一个函数,而是脚本文件(Script),则要在工程目录下找到转换文件的.cpp文件,将其中的C代码拷贝到需要调用它的函数里面,也可以按照MATCOM的语法(类似Matlab的语法)直接进行编写。Matcom还可以实现函数的嵌套。当所编译的.m文件依赖于其他.m文件时,只要把被调用的.m文件与要编译的.m文件放在同一目录下,把生成的被调用文件的.h和.cpp文件插入到VC开发的工程中就可以了。

~~~~~~~~~~~~~~~好好学习~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2008-12-05 15:12



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-247841-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.056222 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved