Dependency management & package manager like pip in ML

52 Ansichten (letzte 30 Tage)
Jan Kappen
Jan Kappen am 6 Feb. 2023
Kommentiert: Ernst van der Pols am 13 Mär. 2025 um 8:41
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 Kommentar
Jan Kappen
Jan Kappen am 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

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

Michelle Hirsch
Michelle Hirsch am 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.
  15 Kommentare
Michelle Hirsch
Michelle Hirsch am 12 Mär. 2025 um 18:09
Thanks, @Ernst van der Pols. This is all quite helpful. I'll pass it along to the team.
I agree that lack of support for proper file system repositories is still the biggest gap with the package manager. We knew that before we shipped - our interviews suggested maybe half of interested users could at least make do with a file system repository. I wish support for Artifactory and others were coming faster, but it's taking a while. The teams are putting a lot of effort into unifying our underlying installation technology to ensure we have a very solid foundation that can support installing MathWorks products and user-authored packages long into the future.
Ernst van der Pols
Ernst van der Pols am 13 Mär. 2025 um 8:41
I fully understand, @Michelle Hirsch, the problems that have to be solved for such a feature and perhaps some frustration on your side just offering "half" a solution. Although, I can only image the effort it takes with each new release of MATLAB to have all the diverse topics and features again in a trustworthy product that so many peoply in the world rely on. And that already over such a long period of time. So, don't worry on taking some time for it. We are still in the process of making colleagues aware of the benefits of having tested matlab code available from a shared location, and the Toolbox is already helping in that way.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Introduction to Installation and Licensing finden Sie in Help Center und File Exchange

Produkte


Version

R2022b

Community Treasure Hunt

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

Start Hunting!

Translated by