Skip to main content

Lightweight sensor modeling package

Project description

Bildkedde

An extensible imaging system simulation library utilizing an MTF and image chain approach.

Roadmap

  1. Basic algorithms and classes with routines in numpy/scipy for spatial/time<->frequency domain transforms on the fly
  2. Dedicated Image or Array object for describing slices of any step of the optical imaging chain at any point during processing
  3. Actual sensor model objects (both high-level for beginners + API simplicity, and low-level for flexibility - including some factories and 'class converter' decorators!!!)
  4. Providing some sort of linking structure (networkx or possibly utilizing IP)
  5. Improvements to the API + simplifying common routines to single callables
  6. LISTED LAST, BUT MOST IMPORTANT: Integrate sensor model standards from other fields and work on white paper + documentation describing and citing process IN DETAIL

TODO

  • Fourier transform stuff for far-field (Fraunhofer) imaging
  • Can I even bother with (Fresnel) near field for this?
  • Investigate available python optics libraries (for now we're assuming abberations and distortion are calculated independently)
  • Image object
  • Object object
  • MTF(abs)/OTF(complex) object
  • PSF object
  • PRF/PixelTF object (requires knowledge of FPA properties such as sampling and pixel dimensions, but useful for analytics and processing tricks!)
  • HDF5 (or numpy) LUT support
  • Element object (basically a processor instance. call func stores the primary input as the impulse, and processing can also be delayed or run immediately (by default). Has input/impulse/object, output/response/image, transfer properties, all of which are objects with spatial and frequency properties, and also a during/z/t(normalized_z_or_time_slice) which can be implemented to render the effects of space-time-dependent transfer function as the wavefront/input travels through the element.
  • System object (consists of our graph of optical/electronic/modifier/mathematical elements) -> This will be base for Optics/FPA/Readout

Library Structure

  • Core
    • Fourier Transforms
    • Fraunhofer and Fresnel support
    • Randomness/Noise
    • Basic array math support
    • GPU array support (CUDA Python cupy, pytorch, and/or Numba support?)
    • Base interfaces to inherit from
      • Chain object
      • Link object
  • Image
  • Noise
  • Optics
  • Radiometry
  • Sensor

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

bildkedde-0.0.1.dev0.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

bildkedde-0.0.1.dev0-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file bildkedde-0.0.1.dev0.tar.gz.

File metadata

  • Download URL: bildkedde-0.0.1.dev0.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.5

File hashes

Hashes for bildkedde-0.0.1.dev0.tar.gz
Algorithm Hash digest
SHA256 140c6fbd760de1e4f2503124e5c7bdd27815ae08d8b9ec543c951997111f4d2e
MD5 0d3a2e0a16e484f13e4f628391187a1d
BLAKE2b-256 085d2f5913b88b0dca609393153ef92e3faf7645c3502fa7d0a1fc0e19395d66

See more details on using hashes here.

File details

Details for the file bildkedde-0.0.1.dev0-py3-none-any.whl.

File metadata

  • Download URL: bildkedde-0.0.1.dev0-py3-none-any.whl
  • Upload date:
  • Size: 8.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.5

File hashes

Hashes for bildkedde-0.0.1.dev0-py3-none-any.whl
Algorithm Hash digest
SHA256 6f0f0083f7dc5b76e9e6159f51c8d114ae6a37e6ef5eda4c3acf6c92b181302e
MD5 26129434f43c4b95bc5a0ef450232f0f
BLAKE2b-256 46328f4390a56fa6af9cb36a3ffa9760390d676e532737798adc30f1b497f321

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page