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.

Currently, the supported packages are:

Using packages in MATLAB

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

% Import a package (adds it to the path for the current session)
mip.import('package_name')

% or
mip import 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 and a setup.m that gets called on import
  • 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 import 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.1.4.tar.gz (19.6 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.1.4-py3-none-any.whl (22.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mip_package_manager-0.1.4.tar.gz
  • Upload date:
  • Size: 19.6 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.1.4.tar.gz
Algorithm Hash digest
SHA256 4baaff1101aefa0a80aec8b4a41d2cd29c408987fb2207c23ca1264a2c28ca46
MD5 5a302d6515cd17a7c60dd8756e8107b2
BLAKE2b-256 519bd1d0937cf9201122b9adead355dc6cf7201c45e2dd5bffca4f64a08b7e83

See more details on using hashes here.

Provenance

The following attestation bundles were made for mip_package_manager-0.1.4.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.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for mip_package_manager-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 74ffdc159d97f137d96192818fcd15bb25784ecfb2e479b0c825c54d9196abef
MD5 1bbaad794c060b975e8f90f8dc52e7ca
BLAKE2b-256 49eab74f4c0eeba6a1427565deef3c798dd8371987f77e0367d8e16f0445b9b8

See more details on using hashes here.

Provenance

The following attestation bundles were made for mip_package_manager-0.1.4-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