Skip to main content

Nion utility classes.

Project description

The Nion Utils library (used in Nion Swift)

Nion utility classes.

package

Latest PyPI version

More Information

Introduction

A utility library of useful Python objects.

  • Events

  • Observable

  • Bindings, Converters, Models

  • Geometry

  • Persistence

  • Process, Threads

  • Publish and Subscribe

  • Reference Counting

  • Stream

  • Structured Model

These objects are primarily used within the Nion Python libraries, but may be useful in general usage too.

This project is funded by Nion Co. as part of the Nion Swift imaging and analysis platform. The code is available under the Apache License, Version 2.0.

Requirements

Requires Python 3.12 or later.

Getting Help and Contributing

If you find a bug, please file an issue on GitHub. You can also contact us directly at swift@nion.com.

This is primarily a library focused on providing support to higher level Nion Python libraries. If you are using this in your own project, we will accept bug fixes and minor feature improvements via pull requests. For larger features or additions, please contact us to discuss.

This library includes some direct tests, but is also tested via other Nion Python projects. Any contribution will need to pass the entire suite of tests. New contributions should be submitted with new tests.

Summary of Features

Events

Events can be used by objects to notify other objects when something of interest occurs. The source object “fires” the event, optionally passing parameters, and the “listener” receives a function call. The source object determines when to fire an event. The event can have multiple listeners. The listeners are called synchronously in the order in which they are added, and the source can fire unconditionally, or until a listener returns True or False.

from nion.utils import Event

class Telescope:
  def __init__(self):
    self.new_planet_detected_event = Event.Event()

  def on_external_event(self, coordinates):
    self.new_planet_detected_event.fire(coordinates)

def handle_new_planet(coordinates):
  print("New planet coordinates at " + str(coordinates))

telescope = Telescope()
listener = telescope.new_planet_detected_event.listen(handle_new_planet)

listener.close()  # when finished

Observable

The Observable based class defines five basic events for watching for direct changes to an object such as a property changing, an object being set or cleared, or an item being inserted or removed from a list. The observable is used along with events to implement bindings.

from nion.utils import Observable

class MyClass(Observable.Observable):
  def __init__(self):
    self.__weight = 1.0

  @property
  def weight(self):
    return self.__weight

  @weight.setter
  def weight(self, new_weight):
    self.__weight = new_weight
    self.notify_property_changed("weight")

myc = MyClass()

def property_changed(key):
  if key == "weight":
    print("The weight changed " + str(myc.weight))

listener = myc.property_changed_event.listen(property_changed)

listener.close()  # when finished

Bindings, Converters, Models

Bindings connect a value in a source object to a value in a target object. Bindings can be one way bindings from source to target, or two way bindings from source to target and from target to source. Bindings can bind property values, lists, or an item in a tuple between the source and target. Bindings work using the Observable events and subsequently are implemented via Events.

Bindings can optionally make value conversions between the source and target. For instance, a binding between a float property and a user interface text field will need to convert from float to string and back. Converters between value and strings are included for integer, float, percentage, check state, and UUID to strings.

Geometry

Classes for integer and float based points, sizes, and rectangles are included. Additional geometry routines are also included, for instance: line midpoint.

Persistence

The PersistentObject based class defines a basic structure for storing objects and their relationship to each other into a persistent storage context. PersistentObjects can store basic properties, single objects (to-one relationship) and lists of objects (to-many relationship). Subclasses must strictly notify the PersistentObject of changes to their persistent data and follow certain guidelines. Doing so allows the object to be stored persistently and restored from persistent storage.

Properties in the PersistentObject can have validators, converters, change notifications, and more. Items and relationships have change notifications and more.

The PersistentStorageContext defines an interfaces which manages a collection of PersistentObjects. It must be able to store a simple dict structure for properties, items, and lists.

Process, Threads

Process defines classes to facilitate a threaded queue, which executes its items serially, and thread set which executes the most recent item in the set.

ThreadPool defines a threaded dispatcher with the ability to limit dispatch frequency and a thread pool with the ability to execute explicitly without threads for testing.

Publish and Subscribe

Publish and subscribe implements a basic publish and subscribe mechanism. It is should be considered experimental and is not recommended for use.

Reference Counting

The ReferenceCounted base class provides an explicitly reference counted object that is unique from regular Python reference counting in that it provides precise control of when the reference is acquired and released. The about_to_delete method is called when reference count reaches zero.

Stream

The Stream classes provide a async-based stream of values that can be controlled using standard reactive operators such as sample, debounce, and combine. The stream source is an Event named value_stream and the source object must provide both the value_stream and a value property.

Structured Model

The Structured Model classes provide a way to describe a data structure which can produce a modifiable and observable object to be used as a model for other utility classes such as binding and events.

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

nionutils-4.14.2.tar.gz (58.1 kB view details)

Uploaded Source

Built Distribution

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

nionutils-4.14.2-py3-none-any.whl (67.8 kB view details)

Uploaded Python 3

File details

Details for the file nionutils-4.14.2.tar.gz.

File metadata

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

File hashes

Hashes for nionutils-4.14.2.tar.gz
Algorithm Hash digest
SHA256 9db23aa6ca79a9552929963045c4997a2bfd93bad62e245e7856a397f7b539c0
MD5 1da1b7190c1f484a271b634b045dc216
BLAKE2b-256 d099d59b7567beecafdbd52e9cd1f20356a2c4384a06612ec0d32efc1a95bf89

See more details on using hashes here.

Provenance

The following attestation bundles were made for nionutils-4.14.2.tar.gz:

Publisher: python-package.yml on nion-software/nionutils

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

File details

Details for the file nionutils-4.14.2-py3-none-any.whl.

File metadata

  • Download URL: nionutils-4.14.2-py3-none-any.whl
  • Upload date:
  • Size: 67.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for nionutils-4.14.2-py3-none-any.whl
Algorithm Hash digest
SHA256 44001438b60a88f79a46606a60c413f7cc91c614e243b7281f473dcb79c77ad5
MD5 6ea66336a2b72392b290217318963e94
BLAKE2b-256 2d1753d0812f7a472194a1d925da5648bdf978cf2e39a32432a6f7e7e3034f71

See more details on using hashes here.

Provenance

The following attestation bundles were made for nionutils-4.14.2-py3-none-any.whl:

Publisher: python-package.yml on nion-software/nionutils

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