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.2.tar.gz (15.3 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.2-py3-none-any.whl (15.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mip_package_manager-0.1.2.tar.gz
  • Upload date:
  • Size: 15.3 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.2.tar.gz
Algorithm Hash digest
SHA256 77816255a9f72bb9ecdeab9f8340f798691d2c88f2e73524453618a43269595c
MD5 651379dd676905febd49cb81c25fdb43
BLAKE2b-256 313183b074b444c042b0cb42bd8feebdbc373cfe69438a2b3b1ce504bf7da990

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for mip_package_manager-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 997f30ed80436f3c9889a98de12ddef9a777c23ba57a92ef3846b4f5ab0e3c17
MD5 63f4e7b0cbc9c3ded4ffbbce90e9dbf5
BLAKE2b-256 ce0b9596e2900b4824e43c196fa5b839b2f295d4a9ae15783a395184308e1e9d

See more details on using hashes here.

Provenance

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