-
Notifications
You must be signed in to change notification settings - Fork 117
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
Extending PHD2 for Planetary Guiding #1187
base: master
Are you sure you want to change the base?
Conversation
Adding reference to Wiki pages of the project (surface feature detection has been excluded from this PR, as it needs more testing). |
Few sections of a presentation given at Memphis Astronomical Society (MAS) by Brent Ellis shortly after the great solar eclipse, where he talks about his experience with Planetary Guiding tool (I renamed it recently from Planetary Tracking to Guiding, as it seems more appropriate): |
This look interesting, but for me it not compile on Linux because of opencv. /home/pch/source/phd2/phd2/guider_planetary.h:37:10: fatal error: opencv/cv.h: No such file or directory I not have cv.h anywhere in my system despite libopencv-dev is installed. But is it really required? |
I should note that this tool has been developed and compiled only for the Windows platform. I would appreciate assistance from other developers in adapting it for other platforms, including Linux and Mac, which I currently do not have access to. |
In this case you must add conditional to compile it only on Windows and not make the phd2 compilation to crash on Linux. |
I find a bit more on this subject. The easier solution for now is to compile your new code only on Windows since you can probably still use a previous version of opencv in VS. |
That can certainly be done, but unless it's proven that it cannot run on Linux, I'd prefer to explore how we might adapt the code to compile on different platforms, if feasible. |
@pchev answering your question - yes, opencv is required by this extension, but depending on the platform it may require some adaptation, which I'm not able to test and verify at this time. |
OK, I also prefer if we can make it to work on Linux and Mac, but I don't know how much of the code use opencv and what effort this require. Because I don't know anything about opencv I start to read this page about VS: There is an example code in the section "Test it!" So making the same opencv code to work on Windows and Linux is not a problem, the problem is only the removal of the C API you use in opencv version higher than 4. If you can upgrade your code to use the C++ API, like the example I mention above is using, it will work on any platform that use opencv version 4. |
Hey this is great work ! |
I may have been premature in creating this PR; it would have been more appropriate as a code review or a request for assistance to ensure compilation and functionality under Linux and OSX. I must acknowledge my oversight in not consulting the build instructions for Linux or OSX. I incorrectly assumed, without verification, that these platforms would use the same OpenCV 2.4 version as Windows. While updating to newer versions of OpenCV is an option, it would necessitate changes to the source code due to the evolution of the OpenCV API since version 2.4. If feasible, deploying the OpenCV 2.4 package on Linux or OSX would be my preferred approach. |
I should clarify that I was building on the existing OpenCV 2.4 library already integrated into PHD2 for Windows. I haven't introduced a new library; I simply utilized the existing framework. |
It is not possible to include an old version of opencv with phd2 on Linux because the build is different on every distribution version depending on the opencv own requirement. Can you try if the example code I mention above work with opencv 2.4 in your environment? Normally the C++ API is available in version 2 and deprecated after version 2.4. |
@pchev , thank you for the suggestion. I can attempt to remove including "opencv/cv.h" and transition from C-style to the C++ API while continuing to use OpenCV 2.4. However, I'm not sure I fully understand your point. If you're saying that OpenCV 2.4 isn't available for all Linux distributions and versions, why should we continue using it? |
I would be in favor of updating the Windows OpenCV to to opencv4 so that all the platforms are up to date with the most recent opencv major version. Ideally this would be a separate PR that would merge to master before this pr. @Eyeke2 would you like to work on this or would you like me to do it? I would not mind doing it, but if you want to take it that is fine too. |
@agalasso I'm not very familiar with the PHD2 build system, which involves git cloning and integrating external components. I would greatly appreciate it if you could update PHD2 with the latest version of OpenCV. Once updated, I'll take it from there, rewriting some sections of the planetary guiding code to adapt it to the latest OpenCV API. |
@agalasso , upgrading to opencv4 would be ideal, but I fear this break cam_opencv that use the old API. |
@pchev @agalasso I assume that PHD2 used OpenCV solely because of cam_opencv. Does this setup compile under Linux/OS X, or is it only functional on Windows? If cam_opencv cannot be updated to the newer version of OpenCV, we might consider using two different versions of OpenCV simultaneously, since the binary library filenames differ and the include files can be installed in separate directories. |
let's not go there -- better to keep all platforms synchronized as much as possible. I'll put up a pr shortly upgrading to opencv4 (including whatever changes are needed for cam_opencv) |
@agalasso Certainly, that's a preferable approach. Using two different versions simultaneously can be challenging because of potential namespace collisions. |
#1188 updates opencv |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Leo, nice work on this feature!
It will be great to get this merged, but this pr needs to be split into more digestable pieces that can be reviewed and merged separately. There's too much code change in this pr for us to review with confidence in a reasonable amount of time.
Some possible pieces that could be separated out into individual prs:
- whitespace cleanup -- make a dedicated pr for that; that alone will reduce the number of files in this pr
- cleanup of spelling errors in comments
- adding comments to existing code
- ascom changes
- simulator changes
- lots of independent changes like the change in camera.cpp could be standalone prs
If you need more detailed suggestions on what could or should be a good standalone pr, let me know and we can discuss further. Ideally each pr should be small and focsued enough that the other developers can look at it in a short amount of time (minutes, not hours) and conclude that it is a good, safe code improvement or extension. You can find articles online that talk about how to make small, reviewable prs (and why it is important); I can also elaborate if you need more info.
gear_simulator.cpp
Outdated
* Copyright (c) 2006-2010 Craig Stark | ||
* Copyright (c) 2015-2018 Andy Galasso | ||
* Copyright (c) 2023-2024 Leo Shatz |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We're not doing copyrights for individual developers any more. All new code should be
* Copyright (c) 2023-2024 Leo Shatz | |
* Copyright (c) 2024 openphdguiding.org |
We want to give developers due credit and always add developers to the list of contributors in Help>About
But having specific copyright notices from every contributor is not scalable and makes it very difficult to follow the BSD 3-clause license which requires the copyright statement be repeated in all software distributions.
I have slowly been converting all the copyright statements that have my name to the form above (openphdguiding.org), and requesting that contributors do the same.
@agalasso Thanks! I'm ok with creating several PRs for minor updates, but for the core algorithm used in detection and its UI, I need to know if I should also divide them into smaller parts. Deconstructing them could be challenging. My plan was to make a single commit that includes the complete code of the new modules with minimal integration into the existing PHD2 framework, followed by a series of commits that fully integrate the new tool with the rest of the system. Regarding copyright, I want to ensure that intellectual property is maximally protected under the current BSD license, especially for the core module containing the detection algorithm. |
@agalasso thanks for upgrading to opencv4. I've converted the planetary code to use the new API while I'm still working on more internal testing and code refactoring, so new PRs are few days away. So far looks good. |
@Eyeke2 , please tell me when you have a branch I can try with Linux. |
@pchev I have rebased this branch to latest master with opencv4 and updated planetary code to use the C++ API. You can try it now with Linux. I still have to break it into smaller PRs as Andy had suggested. |
Thank you! it work on Linux now. I have to make two small change to complete the compilation.
diff --git a/guider_planetary.h b/guider_planetary.h +#if !defined(ARRAYSIZE)
diff --git a/planetary_tool.cpp b/planetary_tool.cpp #include <wx/valnum.h> static bool pauseAlert = false; |
@pchev Thank you for the fixes! It seems easier than I anticipated! We will need someone to test the planetary guiding on Linux. I'm not sure if the camera simulator is available for Linux, but if it is, it could be used for testing in simulator mode by loading an image of the Sun or Moon. |
I tested with the simulator using different solar and planetary images. The only thing that not work, but this is expected, is to modify the tracking rate from the planetary tool. |
@pchev that's wonderful to know. I haven't implemented tracking and its speeds for INDI mounts, as I'm less familiar with its APIs. There are really two options here - either disable these elements for Linux/MacOS platforms, or implement the relevant methods, as you have suggested. The idea of bringing these controls to planetary guiding tool is to streamline the user experience. |
A good starting point might be to disable the mount control group for Linux/OSX in the initial release and consider adding it later, after merging with the master branch. |
00b4ff1
to
7b8d4e8
Compare
…comments Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
…bled for the detection of large celestial bodies such as the Sun, Moon, and planets. This feature detects them as either full light disks or crescent shapes occurring during eclipses or various Moon phases. This commit lays the foundation for subsequent updates needed to fully integrate this feature into PHD2 and ensure its functionality. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
following changes to its elements, such as adding or removing icons. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
…ng mode and integrate the tool with the PHD2 framework. Use the central point of the detected planetary disk as a guide star. Update status messages for Planetary Guiding mode. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
Planetary Guiding mode and replace HFD star metrics with planet radius or sharpness, which are more relevant for planetary guiding. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
improper sizing of message alerts when the user changes the application window size. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
Changes include making the simulator control dialog box non-modal, which was essential for testing Planetary Guiding, and replacing hardcoded simulation models with dropdown menus. These menus allow users to choose between a star field generator or using file images in JPEG, TIFF, PNG, or FIT formats. Additionally, a hardcoded option remains available under DEVELOPER_MODE, while preserving all other legacy hardcoded options. Other updates include adding a 'Simulate Mount Dynamics' mode, which enables the use of PHD2 for calibration and guiding when selected while using 'Simulator' as the guiding camera. Drift simulation has also been added for both RA and DEC, with an increased range of possible values and a method to shift the input images by fractional number of pixels, aiding in testing and evaluating the planetary guiding tool with images of planets or other solar system bodies. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
…ighter. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
planetary guiding. These metrics include time spent in detecting the light disk, circle matching score on a scale of 0-1, and the accuracy of the detected position versus the actual one in simulator mode. This addition is useful for testing and potentially tuning the planetary detection algorithm. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
…ll as tracking speeds, including sidereal, solar, and lunar. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
…state and select tracking speeds. This feature is currently limited to ASCOM mounts only. Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
Signed-off-by: Leo Shatz <leonid.shatz@gmail.com>
@Eyeke2 It seems v2.6.13dev5-planet.rc3 (on the |
I'm not sure why it's happening, but I haven't changed anything related to opencv since original move to OpenCV 4. Please try cloning the current branch head from https://github.com/Eyeke2/phd2.planetary.git and let me know if it works for you. |
The |
I'm definitely not referring to the master branch, it's irrelevant to this discussion. Please try cloning the current head branch (v2.6.13-planetary) and if that doesn't work, drop the suspected commit with OGMA SDK update, as I have stated earlier. I haven't changed any opencv headers for months. |
No, neither of them works. (I updated my comment for clarity since I first posted it.) The error messages are identical to what @pchev had earlier:
I have installed libopencv-dev. |
I suppose there is a misunderstanding here. The branch 'v2.6.13-planetary' hasn't yet been adapted to use OpenCV 4, it's still using OpenCV 2, since parts of planetary detection algorithms are still using the old OpenCV API. In the meantime you can use the most recent branch with planetary tracking (without surface detection), which is 'solar.rc3'. I was mislead by your first comment, assuming that you've successfully compiled v2.6.13dev5-planet.rc1 under Linux, which is most probably not correct. |
Thanks @Eyeke2 , it makes sense now, and I can indeed get |
After several months of testing with a community of beta testers and successful real-world use for imaging solar eclipse and extended solar activity time lapses, this PR, consisting of a compact set of commits, is ready to be integrated into the main PHD2 codebase. This code has been developed to support solar guiding, enabling the creation of long time lapses of solar activity, as well as guiding on planets or the Moon. These celestial bodies typically appear larger than guiding stars and can also present as crescent shapes. The new algorithm I developed performs well in various conditions, maintaining effectiveness even under partial cloud cover or other obstructions, or when the crescent shape is very thin.
The PR includes changes to the Star Profile display and SNR evaluation, replacing HFD metrics with detected planetary radius or image sharpness measurements, which are useful for the planetary guiding workflow.
The set of commits includes updates to the Gear Simulator code, which was instrumental for testing the new Planetary Guiding tool. This updated simulator can now be used for enhanced testing, allowing users to run PHD2 calibration and guide on stars or planets. It also enables users to test the new Planetary Guiding functionality and practice without the need to connect any physical gear.
Although comprehensive documentation is still in development, I've created Wiki pages for new users and designed tooltips in the new UI to provide interactive help information and explanations. The UI for the new tool is designed to be simple and intuitive.
For planetary guiding, typical RMS values may be slightly higher than when guiding on stars. However, the very short exposure times should mitigate any issues. If necessary, performance can be further enhanced by opting for low pass guiding algorithms.