Security News
Research
Data Theft Repackaged: A Case Study in Malicious Wrapper Packages on npm
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
pymmcore superset providing improved APIs, event handling, and a pure python acquisition engine
pymmcore-plus
extends pymmcore
(python bindings for the C++ micro-manager
core) with a number of
features designed to facilitate working with Micro-manager in pure python/C
environments.
pymmcore_plus.CMMCorePlus
is a drop-in replacement subclass of
pymmcore.CMMCore
that provides a number of helpful overrides and additional
convenience functions beyond the standard CMMCore
API. See
CMMCorePlus
documentation
for details.pymmcore-plus
includes an acquisition engine
that drives micro-manager for conventional multi-dimensional experiments. It accepts an
MDASequence
from useq-schema for
experiment design/declaration.CMMCorePlus
class also fixes a number of
"missed" events that are not currently emitted by the CMMCore API.https://pymmcore-plus.github.io/pymmcore-plus/
pymmcore
directly?pymmcore is (and should probably remain) a thin SWIG wrapper for the C++ code at the core of the Micro-Manager project. It is sufficient to control micromanager via python, but lacks some "niceties" that python users are accustomed to. This library:
pymmcore.CMMCore
object with additional
methodsMMCore
.Configuration
and Metadata
.Enums
rather than int
for various
constantscamelCase
method names from the
CMMCore API are not substituted with snake_case
).Pycro-Manager
?Pycro-Manager is an impressive library written by Henry Pinkard designed to make it easier to work with and control the Java Micro-manager application using python. As such, it requires Java to be installed and running in the background (either via the micro-manager GUI application directly, or via a headless process). The python half communicates with the Java half using ZeroMQ messaging.
In brief: while Pycro-Manager
provides a python API to control the Java
Micro-manager application (which in turn controls the C++ core), pymmcore-plus
provides a python API to control the C++ core directly, without the need for
Java in the loop. Each has its own advantages and disadvantages! With
pycro-manager you immediately get the entire existing micro-manager ecosystem
and GUI application. With pymmcore-plus you don't need to install Java, and you
have direct access to the memory buffers used by the C++ core.
from pip
pip install pymmcore-plus
# or, add the [cli] extra if you wish to use the `mmcore` command line tool:
pip install "pymmcore-plus[cli]"
# add the [io] extra if you wish to use the tiff or zarr writers
pip install "pymmcore-plus[io]"
from conda
conda install -c conda-forge pymmcore-plus
dev version from github
pip install 'pymmcore-plus[cli] @ git+https://github.com/pymmcore-plus/pymmcore-plus'
Usually, you'll then want to install the device adapters. Assuming you've
installed with pip install "pymmcore-plus[cli]"
, you can run:
mmcore install
(you can also download these manually from micro-manager.org)
See installation documentation for more details.
Then use the core object as you would pymmcore.CMMCore
...
but with more features :smile:
from pymmcore_plus import CMMCorePlus
core = CMMCorePlus()
...
See a number of usage examples in the documentation.
You can find some basic python scripts in the examples directory of this repository
Contributions are welcome! See contributing guide.
FAQs
pymmcore superset providing improved APIs, event handling, and a pure python acquisition engine
We found that pymmcore-plus demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Research
The Socket Research Team breaks down a malicious wrapper package that uses obfuscation to harvest credentials and exfiltrate sensitive data.
Research
Security News
Attackers used a malicious npm package typosquatting a popular ESLint plugin to steal sensitive data, execute commands, and exploit developer systems.
Security News
The Ultralytics' PyPI Package was compromised four times in one weekend through GitHub Actions cache poisoning and failure to rotate previously compromised API tokens.