Dependency management & package manager like pip in ML

9 views (last 30 days)
Hi all,
Matlab is officially still lacking a proper package manager like npm or pip. I do not understand how people structure projects with dependencies. I understand, there are
  • ML projects
  • ML toolboxes
  • several mpm versions
Toolboxes have a version number attached, projects have not. Both can be shared as a package. Projects can reference other projects, but that 1. requires the same folder structure on every developer PC and 2. requires that the correct version is checked out from the VCS (which is GIT in our case). There's no way to define "project abc@v1.2.0" as a dependency. Just folders/prj files.
How do you do complex app developments? Like a frontent GUI app that needs several self-created toolboxes and projects? The only way is to use GIT (submodules in worst case) to do dependency managment, and that's definitely a red flag.
Then, there's Matlab's mpm matlab-dockerfile/MPM.md at main · mathworks-ref-arch/matlab-dockerfile (github.com) but that's meant to be used to install different product versions and addons, and there's a third party mpm mobeets/mpm: Simple Matlab package management inspired by pip (github.com) which seems to be interesting, but there's no direct support from Mathworks.
Then, it seems like there's another mpm built-in in ML 2022b that mentions a Matlab -packages flag which is very interesting:
mpm
Error using mpm
This command is not supported when the packages feature is not enabled. Start MATLAB with the -packages command line switch.
There's no information about that. Starting ML with -packages reveals more:
Which seems to support different versions. But there's no documentation anywhere, and it's a built-in function © 2022.
What does that mean? Will there be a Mathworks' supported package manager? What exactly is a package by the way in ML? So far, packages were a synonym to namespaces, using the +package folders. How does that work together with ML projects?
I'm in the process of re-structuring code due to a migration from Bitbucket to Gitlab and I'm at a point where a proper dependency management must take place, and that must work in CI/CD, too.
Would be very happy to hear your thoughts.
Thanks,
Jan
  1 Comment
Jan Kappen
Jan Kappen on 9 Aug 2023
Any updates from Mathworks?
I'd really like to know if theres something on its way or if I have to create my own dependency manager, probably in Python.
Thanks

Sign in to comment.

Accepted Answer

Michelle Hirsch
Michelle Hirsch on 9 Aug 2023
We are working on a package management system for MATLAB. The mpm comand you found in MATLAB was from an early beta test we ran in R2022b to flesh out some of the basic principles of the system we are designing.
I think the best bet would be for us to connect you with an appropriate expert or two at MathWorks to talk through ideas of how to best approach meeting your needs now while setting yourself up to adopt our system when it is ready. I'll email you through your author profile to make the connection.
  8 Comments
Michelle Hirsch
Michelle Hirsch on 29 Oct 2024
Thanks, @Jan Kappen. What do you have in mind with Git integration, beyond a self-hostable package registry server in GitLab or the like? MATLAB already has decent git integration for the development of the package source code. I do think that the biggest missing piece is flexible support for package repositories beyond just a shared file system, e.g. Artifactory, or a GitLab package registry.
Jan Kappen
Jan Kappen on 29 Oct 2024
> I do think that the biggest missing piece is flexible support for package repositories beyond just a shared file system, e.g. Artifactory, or a GitLab package registry.
I agree :)
Until this exists, a local package meta data repository could make sense, something like a big json file telling MATLAB "this package is available in this and that version and can be found under this git link + revision". If the package does not exist in a local cache, it gets downloaded.
That way, we would avoid that all packages must be accessible from all MATLAB PCs, and instead just the meta data file can be distributed.
Or even easier: have a dependency list in each project with the link to git in the current version (url + rev), similar to buildinspace/peru: a generic package manager, for including other people's code in your projects

Sign in to comment.

More Answers (0)

Categories

Find more on Source Control in Help Center and File Exchange

Products


Release

R2022b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!