Transplant
-
Transplant所实现的是一个Matlab的python客户端,可以启动Matlab服务器并传送经过Json编码的消息,
-
Transplant通过ZeroMQ将JSON发送到Matlab,并在Matlab解析JSON。
-
Matlab中的matrices和numpy的arrays可以相互转换。
Transplant vs Matlab Engine for Python (MEfP)
使用
效率
- 启动时间:在MEfP中启动一个Matlab实例的时间(3.8 s)比在移植中(6.1 s)短。但由于这样做的情况相对较少,因此差异通常不会太大
- 运行效率:横坐标是参数规模,纵坐标是执行时间。参考上图即可。
优势
只需要pip install Transplant即可启用Matlab()进行远程调用,不用配置engine即可完成,更方便简单。
注意
-
需要将matlab的bin文件夹添加到系统环境变量
-
在调用transplant的时候会自动将当前py所在的文件夹加入matlab的环境变量中,但是如果在其他文件夹下面还有matlab文件和函数,有两种方法:
- 在matlab=transplant.Matlab()启动一个matlab实例之后,对matlab调用就相当于在matlab命令行里面输入内容,因此可以matlab.addpath(“F:/Matlabworkspace”)
- 在Matlab的GUI中将文件添加到路径中,这种方式可以持久化。
因为如果是在docker中调用host宿主机的matlab,常常没法打开matlab gui来添加环境变量,用1就更方便。