raytraverse


Nameraytraverse JSON
Version 1.4.4 PyPI version JSON
download
home_pagehttps://github.com/stephanwaz/raytraverse
Summaryadaptive sampling for CBDM
upload_time2024-10-15 15:57:09
maintainerNone
docs_urlNone
authorStephen Wasilewski
requires_python>=3.7
licenseMozilla Public License 2.0 (MPL 2.0)
keywords raytraverse
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ====================
raytraverse (1.4.4)
====================

.. image:: https://img.shields.io/pypi/v/raytraverse?style=flat-square
    :target: https://pypi.org/project/raytraverse
    :alt: PyPI

.. image:: https://img.shields.io/pypi/l/raytraverse?style=flat-square
    :target: https://www.mozilla.org/en-US/MPL/2.0/
    :alt: PyPI - License

.. image:: https://img.shields.io/readthedocs/raytraverse/stable?style=flat-square
    :target: https://raytraverse.readthedocs.io/en/stable/
    :alt: Read the Docs (version)

.. image:: https://zenodo.org/badge/doi/10.5281/zenodo.4091318.svg
   :target: https://zenodo.org/badge/latestdoi/296295567

raytraverse is a workflow for climate based daylight simulation for the
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. The code base has been split into three seperate packages: this
one as well as two others that provide much of the backend functionality.
craytraverse (https://pypi.org/project/craytraverse) is doccumented here and
contains code to run radiance simulations from within python. raytools is
documented here: https://raytools.readthedocs.io/en/latest/ and contains a lot
of the library functions with working with hdr and ray based data. It is its'
own repository because it includes stand alone tools for evaluating hdr images
for glare metrics.

* Free software: Mozilla Public License 2.0 (MPL 2.0)
* Documentation: https://raytraverse.readthedocs.io/en/latest/.


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 .

while raytraverse installs with the necessary essentials of radiance, it is
recommended to also install radiance (see: https://github.com/LBNL-ETA/Radiance/releases
and make sure you or the installer also sets the $RAYPATH variable) this is
especially important if your material or light source definitions rely on .cal
files distributed with radiance, such as perezlum.cal, window.cal, etc.
Missing .cal files or other scene errors can cause raytraverse traverse to
abort with cryptic eror messages (the number value is not meaningful and will be
different every time)::

    python: : Unknown error -1624667552

If you encounter such an error, make sure your scene is valid in your current
environment, using rvu, rpict, or rtrace.


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 2.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. In an empty directory make a file called Dockerfile_first with the following contents::

    # syntax=docker/dockerfile:1
    # docker build -f Dockerfile_first . --tag raytraverse:latest
    FROM python:3.9

    WORKDIR /build
    RUN apt-get update
    RUN apt-get -y install man

    SHELL ["/bin/bash", "-c"]
    RUN pip3 install raytraverse
    RUN curl -s https://api.github.com/repos/LBNL-ETA/Radiance/releases\?per_page\=1 \
    | grep "browser_download_url.*Linux.zip" | cut -d: -f2,3 | tr -d \" | wget -i -
    RUN unzip Radiance_*_Linux.zip
    RUN tar -xzf radiance-*-Linux.tar.gz
    WORKDIR /radiance
    RUN rm -rf bin lib man
    RUN mv /build/radiance-*-Linux/usr/local/radiance/* ./
    RUN rm -rf /build

    ENV RAYPATH=.:/radiance/lib
    ENV MANPATH=/radiance/man
    ENV PATH=/radiance/bin:$PATH
    RUN raytraverse --help
    WORKDIR /working

4. in a command prompt navigate to this folder and run the following to create
   a docker image with raytraverse and radiance installed::

	docker build - --tag raytraverse:latest < Dockerfile_first

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 (note that you may need to change the syntax of "$(pwd)"
   to be compatible with your shell, this works with the basic windows command prompt)::

	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, radiance, and python 3.9
   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, the process is similar to step 4,
   but with a slightly different dockerfile::

	# syntax=docker/dockerfile:1
	# docker build -f Dockerfile_update . --tag raytraverse:latest
	FROM raytraverse:latest

	WORKDIR /build

	SHELL ["/bin/bash", "-c"]
	RUN pip3 install --upgrade --no-deps craytraverse
	RUN pip3 install --upgrade --no-deps clasp
	RUN pip3 install --upgrade --no-deps raytraverse
	RUN curl -s https://api.github.com/repos/LBNL-ETA/Radiance/releases\?per_page\=1 \
	| grep "browser_download_url.*Linux.zip" | cut -d: -f2,3 | tr -d \" | wget -i -
	RUN unzip Radiance_*_Linux.zip
	RUN tar -xzf radiance-*-Linux.tar.gz
	WORKDIR /radiance
	RUN rm -rf bin lib man
	RUN mv /build/radiance-*-Linux/usr/local/radiance/* ./
	RUN rm -rf /build

	ENV RAYPATH=.:/radiance/lib
	ENV MANPATH=/radiance/man
	ENV PATH=/radiance/bin:$PATH
	RUN raytraverse --help
	WORKDIR /working

   and this command::

	docker build - --tag raytraverse:latest < Dockerfile_update

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.4.2 (2023-11-17)
------------------
* updated readthedocsyaml to handle deprecation
* fixed source view point image drawing that caused to large a solar source
  (only effects images, not metrics)

1.4.1 (2023-10-11)
------------------
* fixed bug when using 3 or 4 candidate points for static point samplers
* added benchmark testing to repository
* improved srcviewpoint for use with captured hdrs
* initial work on 3-channel color support for CBDM runs


1.4.0 (2023-01-12)
------------------
* updated image generation for comppressedpoint
* added option to directly sample imagerenderer without transformation
* reorganized code breaking out python libraries into raytools


1.3.10 (2022-12-20)
-------------------
* paralellize sensorintegrator matrix multiplication
* include interpolated/represented area in zonallightresult.rebase() output
* fix scikit-learn in requiirements.txt/setup.py
* add random patch color view to lightpointkd.direct_view() for diagrams

1.3.9 (2022-12-08)
------------------
* improvements to more easily load lightpoints directly from files without context
* api.load_config for better compatibility between scripting/CLI
* change eccentricity model in hvsgsm
* fix bug in autorotate in planmapper when result should be 0 or 90

1.3.8 (2022-11-04)
------------------
* 0 variance bug in image interpolation
* added boundaries to LightResults
* accept dew_point in ttsv format to skydata
* outtput skydata with dewpoint using skydata_dew
* pull gridhdr no longer needs zone if it is embedded in LightResult

1.3.7 (2022-10-26)
------------------
* updated resonse fit in hsvgm
* resolution option for pull 2 hdr cli
* modules directly available from import raytraverse
* ensure parameters set correctly so sun is always resampled in 1compdv
* bug in integrator log showing too many chunks
* rebase method added to basic LightResult
* rewrote lightpoint image interpolation
* SrcSamplerPt no longer uses accuracy, instead, set t0, at t1 with physical units
* t0 and t1 now instance properties (settable from init)
* added direct view options to raytu lp2img (warning, non-fisheye color throws error)
* preserve -ss in direct view sampling
* clean up srcview sampling (always distant) and fix double counting image when rough specular gets re-samples
* new factoring with craytraverse / renderer inheritance fixes rcontrib reset

1.3.6 (2022-07-28)
------------------
* add scale to sensor integrator forr proper unit conversion (lux by default)
* parallel processing in zonallightresult.pull2hdr
* add lightresult.pull2planhdr to match signature of zonallightresult
* add zonallightresult.rebase to make standard lightresult from zonal
* fixed bug in sunsplanekd.query_by_sun that returned all points, not just best matches
* added index() function to resultaxis
* bug fixes in sensorintegrator, needed additional function overrides and index broadcasting
* avoid IndexError at the end of skydata.maskindices
* add lightresult.merge (and cli interface with raytu merge) for combining LightResults
* change chunking of large calls to evaluate for better performance and the save intermediate results
* pass jitterrate to MaskedPlanMapper constructor
* rewrote RadianceFormatter.get_scene() parser, not based on file extensions
* bug in SamplerArea when operating with MaskedPlanMapper, possible to have
  no samples, leading to IndexError, fixed at self._mask initialization so
  atleast one cell is True.
* added gss to raytu imgmetric (no options yet, uses standard observer)


1.3.5 (2022-07-05)
------------------
* better memory management in zonal sensorintegrator
* plot each weight in srcsamplerpt when using detail/color
* slight reorganization in Integrator to accommodate sensorintegrator changes
* fixed bug in pull with -skyfilter but no -skyfill
* allow skydata write without scene
* change default sunrun parameter to -ab 0
* updated installation instructions and Dockerfiles to include radiance installation
* added adpatch for better control over default args in Rcontrib
* 2x speedup in translate.calc_omega by checking for containment before intersection
  left commented code for pygeos method, but it is slower without better way to
  read in voronoi (creation with pygeos only uses small fraction of points).
* formatting change in CLI docstrings to avoid error with latest docutils

1.3.4 (2022-06-21)
------------------
* do not use srcview for local light sources, include atleast 1 level of clean-up
* make sure kd tree is rebuilt when lucky squirrel
* ambient file handling in rtrace
* better memory management in reflection_search (still a problem?)
* new example config with proper settings
* with minsamp > 0 make sure from_pdf returns something so sampling can complete

1.3.3 (2022-06-07)
------------------
* 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.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/stephanwaz/raytraverse",
    "name": "raytraverse",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.7",
    "maintainer_email": null,
    "keywords": "raytraverse",
    "author": "Stephen Wasilewski",
    "author_email": "stephanwaz@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/6a/49/c75caf5c85c8852c9b8512faabd2ad7cdf7f971b5f588098532c4c6eecb9/raytraverse-1.4.4.tar.gz",
    "platform": null,
    "description": "====================\nraytraverse (1.4.4)\n====================\n\n.. image:: https://img.shields.io/pypi/v/raytraverse?style=flat-square\n    :target: https://pypi.org/project/raytraverse\n    :alt: PyPI\n\n.. image:: https://img.shields.io/pypi/l/raytraverse?style=flat-square\n    :target: https://www.mozilla.org/en-US/MPL/2.0/\n    :alt: PyPI - License\n\n.. image:: https://img.shields.io/readthedocs/raytraverse/stable?style=flat-square\n    :target: https://raytraverse.readthedocs.io/en/stable/\n    :alt: Read the Docs (version)\n\n.. image:: https://zenodo.org/badge/doi/10.5281/zenodo.4091318.svg\n   :target: https://zenodo.org/badge/latestdoi/296295567\n\nraytraverse is a workflow for climate based daylight simulation for the\nevaluation of architectural spaces. Built around a wavelet\nguided adaptive sampling strategy, raytraverse can fully explore the daylight\nconditions throughout a space with efficient use of processing power and\nstorage space. The code base has been split into three seperate packages: this\none as well as two others that provide much of the backend functionality.\ncraytraverse (https://pypi.org/project/craytraverse) is doccumented here and\ncontains code to run radiance simulations from within python. raytools is\ndocumented here: https://raytools.readthedocs.io/en/latest/ and contains a lot\nof the library functions with working with hdr and ray based data. It is its'\nown repository because it includes stand alone tools for evaluating hdr images\nfor glare metrics.\n\n* Free software: Mozilla Public License 2.0 (MPL 2.0)\n* Documentation: https://raytraverse.readthedocs.io/en/latest/.\n\n\nInstallation\n------------\nThe easiest way to install raytraverse is with pip::\n\n    pip install --upgrade pip setuptools wheel\n    pip install raytraverse\n\nor if you have cloned this repository::\n\n    cd path/to/this/file\n    pip install .\n\nwhile raytraverse installs with the necessary essentials of radiance, it is\nrecommended to also install radiance (see: https://github.com/LBNL-ETA/Radiance/releases\nand make sure you or the installer also sets the $RAYPATH variable) this is\nespecially important if your material or light source definitions rely on .cal\nfiles distributed with radiance, such as perezlum.cal, window.cal, etc.\nMissing .cal files or other scene errors can cause raytraverse traverse to\nabort with cryptic eror messages (the number value is not meaningful and will be\ndifferent every time)::\n\n    python: : Unknown error -1624667552\n\nIf you encounter such an error, make sure your scene is valid in your current\nenvironment, using rvu, rpict, or rtrace.\n\n\nWindows\n~~~~~~~\n\nCurrently raytraverse is only compatible with macOS and linux operating systems.\nOne way to use raytraverse on a Windows machine is with Docker. In adddition to the Docker\ninstallation, this process will require about 2.5 GB of disk space.\n\n1. Install Docker from: https://www.docker.com/products/docker-desktop/\n   (click on \"Windows\") and then follow the installation instructions.\n2. Open the newly installed Docker Desktop application (you do not need to sign in or create an account)\n3. In an empty directory make a file called Dockerfile_first with the following contents::\n\n    # syntax=docker/dockerfile:1\n    # docker build -f Dockerfile_first . --tag raytraverse:latest\n    FROM python:3.9\n\n    WORKDIR /build\n    RUN apt-get update\n    RUN apt-get -y install man\n\n    SHELL [\"/bin/bash\", \"-c\"]\n    RUN pip3 install raytraverse\n    RUN curl -s https://api.github.com/repos/LBNL-ETA/Radiance/releases\\?per_page\\=1 \\\n    | grep \"browser_download_url.*Linux.zip\" | cut -d: -f2,3 | tr -d \\\" | wget -i -\n    RUN unzip Radiance_*_Linux.zip\n    RUN tar -xzf radiance-*-Linux.tar.gz\n    WORKDIR /radiance\n    RUN rm -rf bin lib man\n    RUN mv /build/radiance-*-Linux/usr/local/radiance/* ./\n    RUN rm -rf /build\n\n    ENV RAYPATH=.:/radiance/lib\n    ENV MANPATH=/radiance/man\n    ENV PATH=/radiance/bin:$PATH\n    RUN raytraverse --help\n    WORKDIR /working\n\n4. in a command prompt navigate to this folder and run the following to create\n   a docker image with raytraverse and radiance installed::\n\n\tdocker build - --tag raytraverse:latest < Dockerfile_first\n\n5. To use raytraverse, navigate to a local folder that contains all necessary\n   files (radiance scene files, sky data, etc.).\n6. Now, in this folder (note that you may need to change the syntax of \"$(pwd)\"\n   to be compatible with your shell, this works with the basic windows command prompt)::\n\n\tdocker run -it --name rayt --mount type=bind,source=\"$(pwd)\",target=/working raytraverse /bin/bash\n\n7. You now have a linux/bash command prompt in an environment with raytraverse, radiance, and python 3.9\n   installed. The currrent directory will be named \"working\" within the linux environment\n   and is a shared resource with the host (changes on the host side are immediately seen in the container and vice\n   versa). When you are finished, exit the linux shell (\"exit\"), then in the (now) windows command prompt::\n\n\tdocker rm rayt\n\n8. for ease of use, you can put these to lines in a .bat file somewhere in your execution PATH,\n   just make sure that docker desktop is running before calling::\n\n\tdocker run -it --name rayt --mount type=bind,source=\"$(pwd)\",target=/working raytraverse /bin/bash\n\tdocker rm rayt\n\n9. to update raytraverse, the process is similar to step 4,\n   but with a slightly different dockerfile::\n\n\t# syntax=docker/dockerfile:1\n\t# docker build -f Dockerfile_update . --tag raytraverse:latest\n\tFROM raytraverse:latest\n\n\tWORKDIR /build\n\n\tSHELL [\"/bin/bash\", \"-c\"]\n\tRUN pip3 install --upgrade --no-deps craytraverse\n\tRUN pip3 install --upgrade --no-deps clasp\n\tRUN pip3 install --upgrade --no-deps raytraverse\n\tRUN curl -s https://api.github.com/repos/LBNL-ETA/Radiance/releases\\?per_page\\=1 \\\n\t| grep \"browser_download_url.*Linux.zip\" | cut -d: -f2,3 | tr -d \\\" | wget -i -\n\tRUN unzip Radiance_*_Linux.zip\n\tRUN tar -xzf radiance-*-Linux.tar.gz\n\tWORKDIR /radiance\n\tRUN rm -rf bin lib man\n\tRUN mv /build/radiance-*-Linux/usr/local/radiance/* ./\n\tRUN rm -rf /build\n\n\tENV RAYPATH=.:/radiance/lib\n\tENV MANPATH=/radiance/man\n\tENV PATH=/radiance/bin:$PATH\n\tRUN raytraverse --help\n\tWORKDIR /working\n\n   and this command::\n\n\tdocker build - --tag raytraverse:latest < Dockerfile_update\n\n10. see the Docker settings for information about resource allocation to the docker container.\n\nUsage\n-----\nraytraverse includes a complete command line interface with all commands\nnested under the `raytraverse` parent command enter::\n\n    raytraverse --help\n\nraytraverse also exposes an object oriented API written primarily in python.\ncalls to Radiance are made through Renderer objects that wrap the radiance\nc source code in c++ classes, which are made available in python with pybind11.\nsee craytraverse (https://pypi.org/project/craytraverse/).\n\nFor complete documentation of the API and the command line interface either\nuse the Documentation link included above or::\n\n    pip install -r docs/requirements.txt\n    make docs\n\nto generate local documentation.\n\n\n\n\n=======\nHistory\n=======\n\n1.4.2 (2023-11-17)\n------------------\n* updated readthedocsyaml to handle deprecation\n* fixed source view point image drawing that caused to large a solar source\n  (only effects images, not metrics)\n\n1.4.1 (2023-10-11)\n------------------\n* fixed bug when using 3 or 4 candidate points for static point samplers\n* added benchmark testing to repository\n* improved srcviewpoint for use with captured hdrs\n* initial work on 3-channel color support for CBDM runs\n\n\n1.4.0 (2023-01-12)\n------------------\n* updated image generation for comppressedpoint\n* added option to directly sample imagerenderer without transformation\n* reorganized code breaking out python libraries into raytools\n\n\n1.3.10 (2022-12-20)\n-------------------\n* paralellize sensorintegrator matrix multiplication\n* include interpolated/represented area in zonallightresult.rebase() output\n* fix scikit-learn in requiirements.txt/setup.py\n* add random patch color view to lightpointkd.direct_view() for diagrams\n\n1.3.9 (2022-12-08)\n------------------\n* improvements to more easily load lightpoints directly from files without context\n* api.load_config for better compatibility between scripting/CLI\n* change eccentricity model in hvsgsm\n* fix bug in autorotate in planmapper when result should be 0 or 90\n\n1.3.8 (2022-11-04)\n------------------\n* 0 variance bug in image interpolation\n* added boundaries to LightResults\n* accept dew_point in ttsv format to skydata\n* outtput skydata with dewpoint using skydata_dew\n* pull gridhdr no longer needs zone if it is embedded in LightResult\n\n1.3.7 (2022-10-26)\n------------------\n* updated resonse fit in hsvgm\n* resolution option for pull 2 hdr cli\n* modules directly available from import raytraverse\n* ensure parameters set correctly so sun is always resampled in 1compdv\n* bug in integrator log showing too many chunks\n* rebase method added to basic LightResult\n* rewrote lightpoint image interpolation\n* SrcSamplerPt no longer uses accuracy, instead, set t0, at t1 with physical units\n* t0 and t1 now instance properties (settable from init)\n* added direct view options to raytu lp2img (warning, non-fisheye color throws error)\n* preserve -ss in direct view sampling\n* clean up srcview sampling (always distant) and fix double counting image when rough specular gets re-samples\n* new factoring with craytraverse / renderer inheritance fixes rcontrib reset\n\n1.3.6 (2022-07-28)\n------------------\n* add scale to sensor integrator forr proper unit conversion (lux by default)\n* parallel processing in zonallightresult.pull2hdr\n* add lightresult.pull2planhdr to match signature of zonallightresult\n* add zonallightresult.rebase to make standard lightresult from zonal\n* fixed bug in sunsplanekd.query_by_sun that returned all points, not just best matches\n* added index() function to resultaxis\n* bug fixes in sensorintegrator, needed additional function overrides and index broadcasting\n* avoid IndexError at the end of skydata.maskindices\n* add lightresult.merge (and cli interface with raytu merge) for combining LightResults\n* change chunking of large calls to evaluate for better performance and the save intermediate results\n* pass jitterrate to MaskedPlanMapper constructor\n* rewrote RadianceFormatter.get_scene() parser, not based on file extensions\n* bug in SamplerArea when operating with MaskedPlanMapper, possible to have\n  no samples, leading to IndexError, fixed at self._mask initialization so\n  atleast one cell is True.\n* added gss to raytu imgmetric (no options yet, uses standard observer)\n\n\n1.3.5 (2022-07-05)\n------------------\n* better memory management in zonal sensorintegrator\n* plot each weight in srcsamplerpt when using detail/color\n* slight reorganization in Integrator to accommodate sensorintegrator changes\n* fixed bug in pull with -skyfilter but no -skyfill\n* allow skydata write without scene\n* change default sunrun parameter to -ab 0\n* updated installation instructions and Dockerfiles to include radiance installation\n* added adpatch for better control over default args in Rcontrib\n* 2x speedup in translate.calc_omega by checking for containment before intersection\n  left commented code for pygeos method, but it is slower without better way to\n  read in voronoi (creation with pygeos only uses small fraction of points).\n* formatting change in CLI docstrings to avoid error with latest docutils\n\n1.3.4 (2022-06-21)\n------------------\n* do not use srcview for local light sources, include atleast 1 level of clean-up\n* make sure kd tree is rebuilt when lucky squirrel\n* ambient file handling in rtrace\n* better memory management in reflection_search (still a problem?)\n* new example config with proper settings\n* with minsamp > 0 make sure from_pdf returns something so sampling can complete\n\n1.3.3 (2022-06-07)\n------------------\n* static light source sampler, directly samples electric lights at appropriate level,\n  will use lots of extra samples with very long thin fixtures\n* color support in lightPointKD and samplers, but for now only works with imagesampler and\n  sourcesampler because need to update skydata to work with color (and handle mixed data)\n* use scene detail in sampler (in this case image reconstruction works better WITHOUT\n  scene detail, new interpolation keywords fastc and highc for context interpolation)\n* consolidated integrator/zonalintegrator and special methods dv/ds into one class\n* changed zonal sunplane query algorithm: filter suns, penalize, query instead of filter suns, sort, filter points\n* removed ptfilter keyword for zonal evaluation (new process does not use)\n* sunplane normalization based on level 0 distance of sampled suns and level 0 distance of areas\n  for level 0 sampled suns\n* SensorIntegrator to process sensorplane results\n* manage stranded open OS file descriptors\n* wait to calculate omega on demand in lightplaneKD\n* removed img2lf in imagetools, creates circular reference, need to add to different module\n* allow None vector argument for lightplane initialization (cconstructs filename)\n* zero pad hour labels in lightresult for proper file name sorting\n* calc_omega method now passes \"QJ\" to qhull which seems to reliable return regions for all points\n  in case of failure, distributed area among points sharing region (moved from integrator.helpers to translate)\n  so LightPointKD can share\n* fixed mistakes in GSS implementation and recalibrated\n\n1.3.2 (2022-04-28)\n------------------\n* force 'fork' for multiprocessing to ensure radiance state is copied to processes\n* restructure radiancerrenderers - not singleton, just a stateful class, pickleable with get/set state\n* dummy skydatamask class useful for intializing with lightresult axes to handle fill\n* value_array method added to ResultAxis for easier syntax\n* settable sigma_c method in hvsgsm\n* make integrator.helpers public for overrides\n* supress warnings from radiance during reflection search\n* implement ZonalIntegratorDV\n\n1.3.1 (2022-04-19)\n------------------\n* moved craytraverse to separate repository, now a requirement\n* implemented glare sensation model, not yet available from CLI\n\n1.3.0 (2022-04-01)\n------------------\n* first version compatible on linux systems\n* changed skyres specification to int (defining side) for consistency with other resolution parameters\n\n1.2.8 (2022-03-15)\n------------------\n* include radius around sun and reflections when resampling view. for 3comp, -ss should be 0 for skyengine\n* handle stray hits when resampling radius around sun\n* new simtype: 1compdv / integratordv\n\n1.2.7 (2022-03-01)\n------------------\n\n* parametric search radius for specguide in sunsamplerpt\n* integratorDS checks whether it is more memory efficient to apply skyvectors before adding points\n* fixed double printing of 360 direct_views\n* exposd lowlight and threshold parameter access to cli (both imgmetric and evaluate)\n* changed to general precision formatting for lightresult printing\n* fixed -skyfilter in pull, needs a skydata file to correctly index, otherwise based on array size\n* new sampling metric normalizations, can now control logging and pbars with scene parameter\n\n1.2.6 (2022-02-19)\n------------------\n\n* add hours when available to skydata\n* proper masking of 360 images\n* integratorDS handles stray roughness from direct patch\n* planmapper, z set to median instead of max, added autorotation/alignment\n* bugs/features/consistency in LightResult, need better usage documentation\n* directviews from cli (only works with sky)\n\n1.2.5 (2022-02-15)\n------------------\n\n* integrated zonal calcs in cli\n* fall back to regular light result when possible (but keep area)\n* fixed bugs in LightResult, ZonalLightResult\n* added physically based point spread calculation that ~matches gregs gblur script, but using acutal lorentzian from reference\n* added blur psf to sources in image evaluation\n\n\n1.2.4 (2021-12-03) (not posted until 2022-02-10)\n------------------------------------------------\n\n* organized command line code\n* use process pool for sun sampler when raytracing is fast (such as -ab 0 runs with dcomp)\n* propogate plotp to child sampler if sampling one level\n* separated utility command line to own entry point. fixed ambiguity in\n  coordinate handedness of some functions (changed kwarg defaults)\n\n1.2.3 (2021-09-03)\n------------------\n\n * fixed rcontrib to work with Radiance/HEAD, radiance version string includes commit\n * daylightplane - add indirect to -ab 0 sun run (daysim/5-phase style)\n * lightpointkd - handle adding points with same sample rays\n * sampler - add repeat function to follow an existing sampling scheme\n * lightresult - added print function\n * scene - remove logging from scene class\n * cli.py\n    * new command imgmetric, extract rays from image and use same metricfuncs\n    * mew command pull, filter and output 2d data frames from lightresult\n    * add printdata option to suns, to see candidates or border\n * make TStqdm progress bar class public\n * include PositionIndex calculation in BaseMetricSet\n     * new metrics: loggcr and position weighted luminance/gcr\n * skymapper: filter candidates by positive dirnorm when initialized with epw/wea\n * imagetools: parallel process image metrics, also normalize peak with some\n    assumptions\n * lightresult: accept slices for findices argument\n * sunsamplerpt: at second and thrid sampling levels supplement sampling with\n    spec_guide at 1/100 the threshold. helps with imterior spaces to find smaller\n    patches of sun\n * positionindex: fix bug transcribed from evalglare with the positionindex below horizon\n\n\n1.2.0/2 (2021-05-24)\n--------------------\n* command line interface development\n\n1.1.2 (2021-02-19)\n------------------\n* improved documentation\n\n1.1.0/1 (2021-02-10)\n--------------------\n* refactor code to operate on a single point at a time\n\n1.0.4 (2020-11-18)\n------------------\n* create and manage log file (attribute of Scene) for run directories\n* possible fix for bug in interpolate_kd resulting in index range errors\n* protect imports in cli.py so documentation can be built without installing\n\n1.0.3 (2020-11-10)\n------------------\n* new module for calculating position based on retinal features\n* view specifications for directview plotting\n* options for samples/weight visibility on directview plotting\n\n0.2.0 (2020-09-25)\n------------------\n\n* Build now includes all radiance dependencies to setup multi-platform testing\n* In the absence of craytraverse, sampler falls back to SPRenderer\n* install process streamlined for developer mode\n* travis ci deploys linux and mac wheels directly to pypi\n* release.sh should be run after updating this file, tests past locally and\n    docs build.\n\n0.1.0 (2020-05-19)\n------------------\n\n* First release on PyPI.\n",
    "bugtrack_url": null,
    "license": "Mozilla Public License 2.0 (MPL 2.0)",
    "summary": "adaptive sampling for CBDM",
    "version": "1.4.4",
    "project_urls": {
        "Homepage": "https://github.com/stephanwaz/raytraverse"
    },
    "split_keywords": [
        "raytraverse"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "03bea2b0192641dbf8c4d4514f053c640413fc42be1c08b09aa3ee26cfa195d1",
                "md5": "f35447e31a89689592f6175a7d445ed8",
                "sha256": "7a1391b9944e6baa73fb66d73a35cfab0244a02656ebd39f801051c60b7856d4"
            },
            "downloads": -1,
            "filename": "raytraverse-1.4.4-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "f35447e31a89689592f6175a7d445ed8",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.7",
            "size": 1207621,
            "upload_time": "2024-10-15T15:57:06",
            "upload_time_iso_8601": "2024-10-15T15:57:06.054037Z",
            "url": "https://files.pythonhosted.org/packages/03/be/a2b0192641dbf8c4d4514f053c640413fc42be1c08b09aa3ee26cfa195d1/raytraverse-1.4.4-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "6a49c75caf5c85c8852c9b8512faabd2ad7cdf7f971b5f588098532c4c6eecb9",
                "md5": "5aa0094e3021d8159d306bf69ee894b2",
                "sha256": "6a9161b555d10360f8135e3da45d2f3f2ab550605ba819b5a20a17586fb90202"
            },
            "downloads": -1,
            "filename": "raytraverse-1.4.4.tar.gz",
            "has_sig": false,
            "md5_digest": "5aa0094e3021d8159d306bf69ee894b2",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.7",
            "size": 7558011,
            "upload_time": "2024-10-15T15:57:09",
            "upload_time_iso_8601": "2024-10-15T15:57:09.011581Z",
            "url": "https://files.pythonhosted.org/packages/6a/49/c75caf5c85c8852c9b8512faabd2ad7cdf7f971b5f588098532c4c6eecb9/raytraverse-1.4.4.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-10-15 15:57:09",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "stephanwaz",
    "github_project": "raytraverse",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [],
    "lcname": "raytraverse"
}
        
Elapsed time: 1.57643s