Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Increase default temperature_tolerance for ZWO cameras #959

Merged
merged 2 commits into from
Mar 5, 2020

Conversation

danjampro
Copy link
Collaborator

Description

The temperature resolution for ZWO cameras is 0.5 deg, meaning that the current default of temperature_tolerance=0.5 can cause camera.is_temperature_stable to undesirably return False. Increasing the default to temperature_tolerance=0.6 for the ZWO cameras solves this problem.

How Has This Been Tested?

Tested running POCS on actual hardware with default value overridden.

Types of changes

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to change)

Checklist:

  • My code follows the code style of this project.
  • My change requires a change to the documentation.
  • I have updated the documentation accordingly.
  • I have read the CONTRIBUTING document.
  • I have added tests to cover my changes.

@danjampro danjampro requested review from wtgee and AnthonyHorton March 3, 2020 02:04
@codecov
Copy link

codecov bot commented Mar 3, 2020

Codecov Report

Merging #959 into develop will decrease coverage by 0.01%.
The diff coverage is n/a.

Impacted file tree graph

@@             Coverage Diff             @@
##           develop     #959      +/-   ##
===========================================
- Coverage    83.09%   83.07%   -0.02%     
===========================================
  Files           80       80              
  Lines         6353     6353              
  Branches       838      838              
===========================================
- Hits          5279     5278       -1     
  Misses         855      855              
- Partials       219      220       +1
Impacted Files Coverage Δ
pocs/serial_handlers/protocol_arduinosimulator.py 99.2% <0%> (-0.4%) ⬇️

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update 04958b2...e9966ca. Read the comment docs.

Copy link
Member

@wtgee wtgee left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, but I'm going to leave for @AnthonyHorton to approve as he's more familiar with the cameras.

Why not change the default for all cameras in camera.py? Or is it just because of the 0.5 tolerance on ZWO and the others presumably won't have those?

@AnthonyHorton
Copy link
Collaborator

AnthonyHorton commented Mar 5, 2020

Why not change the default for all cameras in camera.py? Or is it just because of the 0.5 tolerance on ZWO and the others presumably won't have those?

Yes, the default temperature tolerance value of 0.5C set in the camera base class is only causing a problem for the ZWO cameras, because the resolution of their temperature readings is also 0.5C. Both the FLI and SBIG cameras have higher resolution temperature readings and can easily achieve better than 0.5C stability. Increasing the tolerance for ZWO only is, I think, the right thing to do.

Copy link
Collaborator

@AnthonyHorton AnthonyHorton left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM.

@@ -50,6 +50,9 @@ def __init__(self,

super().__init__(name, ASIDriver, *args, **kwargs)

# Increase default temperature_tolerance for ZWO cameras
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Might be nice to expand this comment to say why this needed to be done too.

add description
@lspitler lspitler self-requested a review March 5, 2020 22:16
Copy link
Collaborator

@lspitler lspitler left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seeing if my approval allows a merge...

@wtgee wtgee merged commit 22532da into panoptes:develop Mar 5, 2020
wtgee added a commit to wtgee/POCS that referenced this pull request Mar 5, 2020
wtgee added a commit that referenced this pull request Jun 1, 2020
* Dockerize

This will merge all the docker components into a new branch in the main repo. As part of milestone 0.7 these items will be cleaned up as a step towards making the docker version the default (i.e. `develop`) version for milestone 0.8.

This is being merged now because there are too many changes within one PR and it will be better to have new PRs that branch off this `docker` branch. This will also allow for installs on new units from the `panoptes` user rather than my personal branches.

* Docker branch upstream merge - WIP (#911)

Keeping `docker` in line with `develop`.

* Update env_file

Adding local user id

* Fixing power entry (#928)

* Minor fixes

* * Excplit teardown of camera for simulator_sdk so we can remove from assigned list. Note that this should ideally be happening by the `__del__` of the `AbstractSDCCamera` but is not getting called.

* Fixtures scopes at function level. Not sure what this will break.

* Adding empty `obstructions` for location config.

* Adding empty `obstructions` for location config.

* Try to download the IERS table before starting travis test

* Remove mongo

* Download IERS

* Core
* Explicitly cast free_space boolean

Camera
* Pass the config_port to the subcomponents
* Allow for a default string representation (needed to help debug object before it has fully initialized)

Debug logging

* * Default str representation for camera subcomponents that haven't been fully initialized.
* Logging statements for debug (will be removed).

* test_pocs

* Updating all the POCSTIME to be more current.
* Lots of debugging for now (I'm about to switch to desktop and want to keep these in)

* Ensure seconds quantity for exptime

* Test POCS

* Update POCSTIMEs and targets.
* Make the used observation a fixture.

* Small log change

* Ensure a float

* Testing should default to testing pointing

* Removing PR debugging.

* Removing PR debugging.

* Changes from #927 (@zacharyt20)

* Changes from #934 (@zacharyt20)

* Ignore vscode project files

* Coverage tests

* Coverage tests (and a few `no cover` cheats)

* PanBase cleanup

* Config server always returns a `None` so skip exception checking here.
* Coverage tests

* Move social messaging test to panoptes-utils

* Updates to linking pretty image to match panoptes-utils

* Make pretty in pocs shell matched to `panoptes-utils`

* Adding `responses` library.

* Removing references to mongo

* Better dockerignore

* Small changes to logging statements for consistency and use with new logger.

* Updating requirements

* Use new version of `panoptes-utils`

* Adding `responses` to main required section. `pip-tools` can't handle
the `extras_require` section so nothing from those can make their way
into `requirements.txt`, which is a bit frustrating.

* Requirements changes
* Updating pyzmq to latest
* Removing tweepy

* Removing `dateparser` and `pyzmq`

* Removing `photutils` and `python-dateutil`.
Other cleanup to setup.py

* Fixing calls to the root logger

* Getting rid of logger calls.

* Fixing caplog for pytest with new logging.

* **BREAKING CHANGE**

Changing `get_root_logger` to the more intuitive `get_logger`

* Logger Fixes

* Switches to `get_logger`
* Better logger config
* Remove old log config file

* Fixing focuser calls to mask_saturated for updates panoptes-utils

* Don't pass logger to write_fits

* Adding custom formatter for console logger so there are even widths for columns

* Singleton console formatter so column widths are retained across imports

* Change some log levels to trace for setup items in testing

* * Handle missing thumbnail creation.
* Smarter wait for cooling cameras so tests don't take as long.
* Better log format for cooling cameras.

* Logger:

* Better singleton
* Better work with pytest
* Moved more thngs to trace level

Filterwheel:

* Increased tolerances on some tests for some reason. 😕

* Breaking some logger coverage for now

* pep8
    * Ignore a few minor violations with new pycodestyle
    * fix some errors

* Requirements:

* Adding all the modules to the `required` section in `setup.py`. This means that `pip-tools` will generate a full and complete `requirements.txt` but is otherwise annoying.
    * Helps to fix some depedency issues in the docker image.

* Removing logger coverage for now

* Allow camera time to properly cool

* Some some debug messages when camera not ready.

* Increase default temperature_tolerance for ZWO cameras (#959)

* override default value

* Updating to `panoptes-utils==0.2.2` to fix testing issues.

* Fix paths to testing script

* Change GH action name

* Update version number.

* Updates to readme

* Auto fix format errors on changelog

* Updates to README and CHANGELOG

* Increase log retention policy

* Changing relevant `super()` calls.

* Remove unused script

* Changelog updates

* Move pdf manuals to resources directory

* Build documentation correctly

* Update readthedocs config

* Split the AAG weather docker containers to separate compose file.

* Fix `super` calls

* Update the install script

* Use `panoptes-exp`
* Remove the branch option
* Only link env file if one doesn't exist
* Newer version of `docker-compose`
* List of docker images updated

* Changing log levels (lots of output)

* * Timeout the GitHub Actions at 60 minutes (default is 6 hours!)
* Fix missing param

* * Don't unpark the mount in the `ready` state but wait until `slewing`.
* Better machine logic logging
* Small cleanup

* Generate all new documentation.

* More fixes for documentation

* Documentation fixes

* Fix tests with regard to parking change

* Change level colors for logger

* Fix url in setup
Fix some docs

* Trying to import cooling_enabled test.

* Don't capture log output

* Small test fixes

* Revert the travis test option

* Slight delay to killing of server so next one can start

* * Update `panoptes-utils`

* Reduce test verbose output

* f-string for vesion (why not?)

* Add back test verbosity (didn't help with GH Actions output)

* Die on first error

* Save log files in github if tests fail.

* Use local path for artifacts.

* Fix GH Actions path

* More trying to fix GH Action path

* Moving coverage upload to gh actions.

* Trying to figure out GHA artifacts

* Apparently need a name

* Fix pipes

* Add back the `failure`

* More GHA test

* GHA tests

* Docker container not a tty

* Try local logs

* More and more and more testing of GHA

* Remove test for testing tests

* Better name for job step

* Change step name for GHA

* Travis consistently fails on this test so attempting to get some debug info.

* Combine covergae in GHA

* z

* Make `coverage` command available.

* Always create log file artifact, only do coverage on success

* Camera tests will always wait for camera to be ready.

* Increase time allowed to get ready and log

* Identify which camera

* Try different wait for camers

* Adding ridiculous debugging.

* Try to debug random temperature spikes

* Better debug logging

* Decrease random temp variance on simulator.

* Just trace the temp instead of debug

* Coverage is combined at the time it is run.

* Lower temp var for simulator

* Set trace log level on CI testing.

* List files to see coverage

* Get some log output

* Use the logger from the camera.

* Compress console log file

* Also list hidden files on success (looking for travis file)

* Add some echoes

* Removing teardown

* Try explicit delete

* Trying to get more debug info on stalling tests

* Only log if have assigned cameras

* Updating panoptes-utils

* Send coverage reports from inside the testing file.

* Correct expression

* I thought I had the `or` working earlier but don't want to spend any more time.

* Coverage

* Explicit GH actions tests to find coverage

* * Opinionated logger forces handlers.
* No `SystemExit` on missig config items.
* Smarter filterwheel timeouts.
* Cleanup `camera` fixture so it skips hardware tests better.
* Adding a `testing` level for logger for differentiating between test output.

* Minor cleanup

* Comment about weird code for removing `simulator_sdk`

* Cheating with not testing caplog

* * Force logger handler singletons by id again. Seems like `loguru` should have a mechanism to track by name.

* Fix coverage artifact

* * Remove ci env and list before upload.

* Don't upload coverage file.

* Try to explictyly upload coverage file

* Show coverage report before uploading.

* Coverage report from test script.

* Test and coverage cleanup.

* * Add coverage upload action to pythontest GHA.
* Consolidate setup files into `setup.cfg`. Also rearrage `setup.cfg`.
    * Remove `.pycodestyle.cfg`
    * Remove `.coveragerc`

* Add to changelog.

* Better step names for GHA

* Fix codestyle test to point to config.

* Rename codecov file to be their selfish top-level name.

* More in changelog.

* * Default the install to the `panoptes` user intead of `$USER`.
* Don't get PAWS repo.

* Remove simple weather script reader and `pandas` dependency (moved to branch in `aag-weather`)

* Consistent script names

* Simplify env file

* Add `$PANUSER` to env file.

* * Revert back to installing with the `$USER`, which makes esnse for the host system.
* Remove `$LOCAL_USER_ID` from env file.

* Install script
* Don't install PAWS.
* Don't use env file (for now?).

Env file
* Move out of `docker` to root of project.

Config file cleanup
* Rearrange.
* Remove weather items.
* Remove social items.

* Install script

* Prompt for PANDIR.

* Remove stale comment

* Clarify misleading env var value

* Remove stale comment

* Clean up coverage and test files

* Use `PanLogger` from the utils.

* Manually addy the panoptes-utils github to requirements for now.

* Fix coverage pointing location.

* Add coverage variables.

* Make sure to add `latest` image.

* Update panoptes-utils

* Update labels and build for docker

* Small cleanups.

* Fixing requirements.

* * Supporting tagged Dockerfile so we can create a `develop` version (TODO).
* Adjusting test so that it builds docker image. Hopefully won't be too slow.

* Switch to panoptes user.

* Update Dockerfile.

* Don't link conf_files. Need a better solution.

* Bringing `PanLogger` (dynamic padding and handler info) from `panoptes-utils`.

* Cleanup of files and ignore files.

* Try to run the GHA tests with GHA user.

* Updates to test and config to try and make more like working panoptes-utils.

* Bumping panoptes-utils requirements

* Removing unnecessary comments.

* Updating test scripts for automated testing inside a container, either local or on CI service.

* Allow the CI service to run as its local user.

* Try GHA testing without local user id.

* Trying to solve log file permissions problem on GHA.

* Can't take time to fix this test as it might be removed.

* * Adding setuptools-scm
* Updating requirements.txt

* Ignore generated version file

* Small docker changes

* PyScaffold migration commit.

* Custom edits to the pyscaffold merge.

* **Breaking**

* Changing pocs namespace to fit within panoptes.

* Fixing tests.

* More big chnages for pyscaffold. Getting the docs and the tests working.

* Add static images

* More documentation updates and fixes.

Some filterwheel tolerance fixes.

* * Changing logging namespace.
* Updating contributing guide and other docs.

* * Cleaing up docker.
* Changing logger namespace back to original.

* * Add `is_sleeping` property.
* Move `parse_lines` into function as a camera utility.
* Using panoptes-utils serializers.

* * Fixing `parse_config` for gphoto2
* Added `is_sleeping` for pocs.
* Dockerfile install local via pip.

* * Adding items from #970.
* Using `panoptes.utils.time.wait_for_events`.
* Install instructions in the README.

* Readme cleanup.

* Readme cleanup.

* Test cleanup.

* * Making proper abstractmethods.
* Documentation updates where found.
* Many log and f-string fixes.
* `pocs.config_port` property available publicly.
* horizon check for state happens directly in `run`.
* `sleep` renamed to `wait`.
* dome status changed to dict.

* Changelog, quick test fixes.

* Fix bad import.

* Fix bad import.

* Install script

* Don't start time service on linux
* Don't write existing env vars to zshrc
* Don't fetch origin if repo already exists
* Always pull docker images
* Don't use sudo for pulling images

* Docker updates to use testing.

* Fixing GHA .

* Update contributing guide.

* Changelog updates.

* Changelog updates.

* Adding an update warning.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants