Skip to main content

adaptive sampling for CBDM

Project description

raytraverse (1.3.3)

PyPI PyPI - License Read the Docs (version) Coveralls github https://zenodo.org/badge/doi/10.5281/zenodo.4091318.svg

raytraverse is a complete workflow for climate based daylight modelling, simulation, and evaluation of architectural spaces. Built around a wavelet guided adaptive sampling strategy, raytraverse can fully explore the daylight conditions throughout a space with efficient use of processing power and storage space.

Installation

The easiest way to install raytraverse is with pip:

pip install --upgrade pip setuptools wheel
pip install raytraverse

or if you have cloned this repository:

cd path/to/this/file
pip install .

Windows

Currently raytraverse is only compatible with macOS and linux operating systems. One way to use raytraverse on a Windows machine is with Docker. In adddition to the Docker installation, this process will require about 1.5 GB of disk space.

  1. Install Docker from: https://www.docker.com/products/docker-desktop/ (click on “Windows”) and then follow the installation instructions.

  2. Open the newly installed Docker Desktop application (you do not need to sign in or create an account)

  3. Create a new local folder and with a file named Dockerfile:

    # syntax=docker/dockerfile:1
    FROM python:3.9
    WORKDIR /working
    SHELL ["/bin/bash", "-c"]
    RUN pip3 install raytraverse
    
    CMD raytraverse --help
  4. in a command prompt navigate to this folder and:

    docker build . --tag raytraverse
  5. To use raytraverse, navigate to a local folder that contains all necessary files (radiance scene files, sky data, etc.).

  6. Now, in this folder:

    docker run -it --name rayt --mount type=bind,source="$(pwd)",target=/working raytraverse /bin/bash
  7. You now have a linux/bash command prompt in an environment with raytraverse installed. The currrent directory will be named “working” within the linux environment and is a shared resource with the host (changes on the host side are immediately seen in the container and vice versa). When you are finished, exit the linux shell (“exit”), then in the (now) windows command prompt:

    docker rm rayt
  8. for ease of use, you can put these to lines in a .bat file somewhere in your execution PATH, just make sure that docker desktop is running before calling:

    docker run -it --name rayt --mount type=bind,source="$(pwd)",target=/working raytraverse /bin/bash
    docker rm rayt
  9. to update raytraverse, just repeat step 4 in a directory with the Dockerfile in step 3.

  10. see the Docker settings for information about resource allocation to the docker container

Usage

raytraverse includes a complete command line interface with all commands nested under the raytraverse parent command enter:

raytraverse --help

raytraverse also exposes an object oriented API written primarily in python. calls to Radiance are made through Renderer objects that wrap the radiance c source code in c++ classes, which are made available in python with pybind11. see craytraverse (https://pypi.org/project/craytraverse/).

For complete documentation of the API and the command line interface either use the Documentation link included above or:

pip install -r docs/requirements.txt
make docs

to generate local documentation.

History

1.3.3

  • static light source sampler, directly samples electric lights at appropriate level, will use lots of extra samples with very long thin fixtures

  • color support in lightPointKD and samplers, but for now only works with imagesampler and sourcesampler because need to update skydata to work with color (and handle mixed data)

  • use scene detail in sampler (in this case image reconstruction works better WITHOUT scene detail, new interpolation keywords fastc and highc for context interpolation)

  • consolidated integrator/zonalintegrator and special methods dv/ds into one class

  • changed zonal sunplane query algorithm: filter suns, penalize, query instead of filter suns, sort, filter points

  • removed ptfilter keyword for zonal evaluation (new process does not use)

  • sunplane normalization based on level 0 distance of sampled suns and level 0 distance of areas for level 0 sampled suns

  • SensorIntegrator to process sensorplane results

  • manage stranded open OS file descriptors

  • wait to calculate omega on demand in lightplaneKD

  • removed img2lf in imagetools, creates circular reference, need to add to different module

  • allow None vector argument for lightplane initialization (cconstructs filename)

  • zero pad hour labels in lightresult for proper file name sorting

  • calc_omega method now passes “QJ” to qhull which seems to reliable return regions for all points in case of failure, distributed area among points sharing region (moved from integrator.helpers to translate) so LightPointKD can share

  • fixed mistakes in GSS implementation and recalibrated

1.3.2 (2022-04-28)

  • force ‘fork’ for multiprocessing to ensure radiance state is copied to processes

  • restructure radiancerrenderers - not singleton, just a stateful class, pickleable with get/set state

  • dummy skydatamask class useful for intializing with lightresult axes to handle fill

  • value_array method added to ResultAxis for easier syntax

  • settable sigma_c method in hvsgsm

  • make integrator.helpers public for overrides

  • supress warnings from radiance during reflection search

  • implement ZonalIntegratorDV

1.3.1 (2022-04-19)

  • moved craytraverse to separate repository, now a requirement

  • implemented glare sensation model, not yet available from CLI

1.3.0 (2022-04-01)

  • first version compatible on linux systems

  • changed skyres specification to int (defining side) for consistency with other resolution parameters

1.2.8 (2022-03-15)

  • include radius around sun and reflections when resampling view. for 3comp, -ss should be 0 for skyengine

  • handle stray hits when resampling radius around sun

  • new simtype: 1compdv / integratordv

1.2.7 (2022-03-01)

  • parametric search radius for specguide in sunsamplerpt

  • integratorDS checks whether it is more memory efficient to apply skyvectors before adding points

  • fixed double printing of 360 direct_views

  • exposd lowlight and threshold parameter access to cli (both imgmetric and evaluate)

  • changed to general precision formatting for lightresult printing

  • fixed -skyfilter in pull, needs a skydata file to correctly index, otherwise based on array size

  • new sampling metric normalizations, can now control logging and pbars with scene parameter

1.2.6 (2022-02-19)

  • add hours when available to skydata

  • proper masking of 360 images

  • integratorDS handles stray roughness from direct patch

  • planmapper, z set to median instead of max, added autorotation/alignment

  • bugs/features/consistency in LightResult, need better usage documentation

  • directviews from cli (only works with sky)

1.2.5 (2022-02-15)

  • integrated zonal calcs in cli

  • fall back to regular light result when possible (but keep area)

  • fixed bugs in LightResult, ZonalLightResult

  • added physically based point spread calculation that ~matches gregs gblur script, but using acutal lorentzian from reference

  • added blur psf to sources in image evaluation

1.2.4 (2021-12-03) (not posted until 2022-02-10)

  • organized command line code

  • use process pool for sun sampler when raytracing is fast (such as -ab 0 runs with dcomp)

  • propogate plotp to child sampler if sampling one level

  • separated utility command line to own entry point. fixed ambiguity in coordinate handedness of some functions (changed kwarg defaults)

1.2.3 (2021-09-03)

  • fixed rcontrib to work with Radiance/HEAD, radiance version string includes commit

  • daylightplane - add indirect to -ab 0 sun run (daysim/5-phase style)

  • lightpointkd - handle adding points with same sample rays

  • sampler - add repeat function to follow an existing sampling scheme

  • lightresult - added print function

  • scene - remove logging from scene class

  • cli.py
    • new command imgmetric, extract rays from image and use same metricfuncs

    • mew command pull, filter and output 2d data frames from lightresult

    • add printdata option to suns, to see candidates or border

  • make TStqdm progress bar class public

  • include PositionIndex calculation in BaseMetricSet
    • new metrics: loggcr and position weighted luminance/gcr

  • skymapper: filter candidates by positive dirnorm when initialized with epw/wea

  • imagetools: parallel process image metrics, also normalize peak with some

    assumptions

  • lightresult: accept slices for findices argument

  • sunsamplerpt: at second and thrid sampling levels supplement sampling with

    spec_guide at 1/100 the threshold. helps with imterior spaces to find smaller patches of sun

  • positionindex: fix bug transcribed from evalglare with the positionindex below horizon

1.2.0/2 (2021-05-24)

  • command line interface development

1.1.2 (2021-02-19)

  • improved documentation

1.1.0/1 (2021-02-10)

  • refactor code to operate on a single point at a time

1.0.4 (2020-11-18)

  • create and manage log file (attribute of Scene) for run directories

  • possible fix for bug in interpolate_kd resulting in index range errors

  • protect imports in cli.py so documentation can be built without installing

1.0.3 (2020-11-10)

  • new module for calculating position based on retinal features

  • view specifications for directview plotting

  • options for samples/weight visibility on directview plotting

0.2.0 (2020-09-25)

  • Build now includes all radiance dependencies to setup multi-platform testing

  • In the absence of craytraverse, sampler falls back to SPRenderer

  • install process streamlined for developer mode

  • travis ci deploys linux and mac wheels directly to pypi

  • release.sh should be run after updating this file, tests past locally and

    docs build.

0.1.0 (2020-05-19)

  • First release on PyPI.

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

raytraverse-1.3.3.tar.gz (7.3 MB view hashes)

Uploaded Source

Built Distribution

raytraverse-1.3.3-py3-none-any.whl (1.2 MB view hashes)

Uploaded Python 3

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