Skip to main content

pip-style package manager for MATLAB packages

Project description

mip-client

⚠️ Warning: This project is at a very early stage of development and is subject to breaking changes.

A simple pip-style package manager for MATLAB packages.

Installation

Install the package using pip:

pip install mip-package-manager

Or install from source:

# First, clone the repository
git clone https://github.com/mip-org/mip-client.git
cd mip-client

# Then, install the package
pip install -e .

To set up the MATLAB integration, run:

mip setup

This command will create the necessary directories and files in ~/.mip/matlab for MATLAB integration.

Then add ~/.mip/matlab to your MATLAB path permanently. You can do this in MATLAB:

addpath('~/.mip/matlab')
savepath

Alternatively, you can add this to your MATLAB startup.m file (typically located at ~/Documents/MATLAB/startup.m):

addpath('~/.mip/matlab')

Note: After upgrading to a new version of mip, run mip setup to ensure you have the latest MATLAB integration.

Usage

Install a package

Either from the command line or from within MATLAB, run:

mip install package_name

Downloads and installs a package to ~/.mip/packages/package_name.

Table of installable packages

Using packages in MATLAB

After setting up the MATLAB path and installing packages, you can load them in MATLAB:

% Load a package (adds it to the path for the current session)
mip load package_name

% Now you can use the package functions

List installed packages

mip list

Shows all currently installed packages.

Uninstall a package

mip uninstall package_name

Removes an installed package after confirmation. Also removes any packages that depend on it.

Internal Package Structure

  • Packages are stored in ~/.mip/packages/
  • Each package is extracted from a zip (.mhl) file into its own directory
  • Each package has a mip.json file containing metadata, a load.m that gets called when the package is loaded, and an unload.m that gets called when the package is unloaded.
  • The +mip MATLAB namespace is installed in ~/.mip/matlab/+mip/

Example

# Install a package
mip install surfacefun

# List installed packages
mip list

# Use in MATLAB
matlab
>> mip load surfacefun
>> % Now use the toolbox functions

# Uninstall
mip uninstall surfacefun

How to add new packages

For now mip supports a very limited set of packages, which are built as part of this repository. To add a new package, you should submit a pull request to https://github.com/mip-org/mip-core.

Requirements

  • Python 3.6+
  • MATLAB

Authors

Jeremy Magland and Dan Fortunato - Center for Computational Mathematics, Flatiron Institute

License

Apache License 2.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mip_package_manager-0.2.0.tar.gz (21.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mip_package_manager-0.2.0-py3-none-any.whl (27.3 kB view details)

Uploaded Python 3

File details

Details for the file mip_package_manager-0.2.0.tar.gz.

File metadata

  • Download URL: mip_package_manager-0.2.0.tar.gz
  • Upload date:
  • Size: 21.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mip_package_manager-0.2.0.tar.gz
Algorithm Hash digest
SHA256 dc26f378319592cf214e37712ac850ce2f50c5b7e69ad1df2606eca35ac30cb3
MD5 c071d014d7e7423f81267beccb0d16db
BLAKE2b-256 117cab0c764662f9ca70b1264c8fb926d3b8f15f2482ba2f3e743ffdf3a9338a

See more details on using hashes here.

Provenance

The following attestation bundles were made for mip_package_manager-0.2.0.tar.gz:

Publisher: publish.yml on mip-org/mip-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mip_package_manager-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mip_package_manager-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a2dd25776ea09e3a10e81dc8516519e375985499e4f613298e5b0a2061a14b3e
MD5 88a48ea1695b63a73bba5d8d798cd466
BLAKE2b-256 341520f22e700d90bdabaac98ad0ba823fa79607332e96d8212512376da364d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for mip_package_manager-0.2.0-py3-none-any.whl:

Publisher: publish.yml on mip-org/mip-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page