Map of Objects---essential parts
Project description
Mapof
This open-source, MIT-licensed package is a core part of the mapof ecosystem. This framework allow for representing various features of (computational) problem instances in the context of the instance structure in a visually appealing way. Mapof is a direct successor of mapel, which will be deprecated in the (unforeseen) future.
Current status of mapof vs mapel
We successively substitute mapel packages present when we decided to start mapof and abandon active development of mapel. Here is the current status:
mapel-core==> mapofmapel-elections==> mapof-elections- mapel-roommates ==> development ongoing
- mapel-marriages ==> developmnet ongoing
Hence, this package, mapof, is a direct successor of mapel-core.
Installation of mapof
There are in principle three (standard to python packages) ways to install mapof. We strongly recommend installing the package from PyPi but you can also: use the code as a local package or install the package from the local code using some package manager.
Installation from PyPi
We recommend installing mapof in a separate virtual environment (we use venv
but any reasonable environment manager should do). Installation from Pypi with
one of Python's package managers allows a seamless usage of mapof with its
remaining modules, that are to come soon, which all declare mapof as
dependency. A drawback is here that one cannot edit the mapof code easily. If
you use pip
type pip install mapof
to get the newest version and your are
ready to go. If you use other package managers, do whatever it usually takes to
install packages from PyPi.
[!TIP] You can still patch mapof using the fact that functions are First-Class Citizens in Python. By separating changes from the actual mapof code, the changes can later be easily changed to pull requests. And we would be very happy if you contribute to mapof. For details, see the section below.
Patching installation from PyPi
To patch function mapof.bar.foo
you can define your own function my_foo
and
then assign it using mapof.bar.foo = mapof.bar.my_foo
. If you do this before
calling mapof.bar.foo
, then each call to mapof.bar.foo
will actually run
your my_foo
function.
Using code locally without package managers
Using the code as a local package is another option. Doing so, by downloading the package and importing different modules directly, comes with an easy way to edit mapof files. However, it enforces usage of all other mapof packages in the very same way. Trying installing other packages via some package manger will most likely result in that you will be using the manager-downloaded PyPi version of the mapof module instead of your handcrafted one (there are workarounds, but you probably know these tricks very well if you ever want to take this path).
Using code locally with package manager
A somewhat compromise solution is to fork the repo and install the package into the package management system using your locally stored (perhaps edited) code. This might have a drawback that you need to update your installation after every change you make in the mapof code.
However pip
offers a handy solution here, the editable mode. Overall, using
pip
you can pass to pip install
the path to the project (where
pyproject.toml
resides) and the -e
switch. By this you get the best of two
world mapof is managed by pip and your modifications of the package are
reflected immediately in the code that uses mapof. This approach also have its
limitations but in most cases it should just work well. In case you experience
troubles, you should see what the pip
documentation has to say about the
editable mode.
Acknowledgments
This project is part of the PRAGMA project which has received funding from the European Research Council (ERC) under the European Union’s Horizon 2020 research and innovation programme (grant agreement No 101002854).
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file mapof-0.1.1.tar.gz
.
File metadata
- Download URL: mapof-0.1.1.tar.gz
- Upload date:
- Size: 2.0 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fa176be57c3403377ccd9fef7f20f9d28050202cb5c287ae0c37c21a0758d49f |
|
MD5 | 70b852b2b87cf05dc3be56d6cf7a3d88 |
|
BLAKE2b-256 | 45a3918a8f9fc2859406ef2a7266c6c4510a164462927ea9710f6e569f8dd90c |
Provenance
The following attestation bundles were made for mapof-0.1.1.tar.gz
:
Publisher:
pypi-publish.yml
on science-for-democracy/mapof
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
mapof-0.1.1.tar.gz
- Subject digest:
fa176be57c3403377ccd9fef7f20f9d28050202cb5c287ae0c37c21a0758d49f
- Sigstore transparency entry: 146138960
- Sigstore integration time:
- Predicate type:
File details
Details for the file mapof-0.1.1-py3-none-any.whl
.
File metadata
- Download URL: mapof-0.1.1-py3-none-any.whl
- Upload date:
- Size: 46.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3a54358ac8299962834f94bb0ca639d7f2699c57912fb5df0781b520b0ba66d6 |
|
MD5 | bdb70869257d4dd44eb1555bba3995c8 |
|
BLAKE2b-256 | aeeceabd1873d9d165b29cbdb344a6b9337eda1f53681e30da67d5832e4d45e8 |
Provenance
The following attestation bundles were made for mapof-0.1.1-py3-none-any.whl
:
Publisher:
pypi-publish.yml
on science-for-democracy/mapof
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
mapof-0.1.1-py3-none-any.whl
- Subject digest:
3a54358ac8299962834f94bb0ca639d7f2699c57912fb5df0781b520b0ba66d6
- Sigstore transparency entry: 146138961
- Sigstore integration time:
- Predicate type: