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

issue/591/triaxiality: Build scripts in examples/triaxiality #603

Open
wants to merge 89 commits into
base: main
Choose a base branch
from

Conversation

shenmingfu
Copy link
Collaborator

@shenmingfu shenmingfu commented Jul 18, 2023

@shenmingfu shenmingfu changed the title built a folder examples/triaxiality, added a readme file inside Build scripts in examples/triaxiality Jul 18, 2023
@coveralls
Copy link

coveralls commented Jul 18, 2023

Coverage Status

coverage: 100.0%. remained the same when pulling f2da93b on issue/591/triaxiality into c6cf806 on main.

@shenmingfu shenmingfu changed the title Build scripts in examples/triaxiality issue/591/triaxiality: Build scripts in examples/triaxiality Jul 18, 2023
@akumgill akumgill self-assigned this Jul 19, 2023
akumgill and others added 19 commits July 19, 2023 14:23
Comparison of Tae's and Adhikari's implementations of quadrupole and monopole components
Includes fitting for orientation of halo and ellipticity simultaneously.
rancesol and others added 14 commits July 19, 2024 10:56
…effects with instructions to use example data (#629)

* feat: Add coordinate_system parameter to compute_tangential_and_cross_components and _compute_lensing_angles functions

* Update documentation to account for new coordinate_system option

* feat: Add coordinate_system conversion test to test_compute_lensing_angles_flatsky function

* Add coordinate_system conversion test to test_compute_lensing_angles_astropy function and fix bug in coordinate system conversion bug in compute_lensing_angles_astropy

* Set coordinate_system option during creation of GalaxyCluster object

* adding a new notebook and data

* test

* new notebook to test coordinate systems and shear measurements

* Removed debuggin print in test_dataops.py

* editing README for the data availability

* moved tomomi's notebook to examples

* added prelude to Tomomi's notebook

* Fixed typo and set default coordinate_system to "pixel"

* Added option to choose coordinate system for generated mock catalog

* Added ellipticity coordinate system conversion tests to test_galaxycluster.py and test_mockdata.py

* Added documentation to other test cases in Tomomi's notebook.  Still need to incorporate Caio's added functionality for sky vs. pixel coordinates in CLMM

* Fixed formatting

* starting to work through and document example of lensing signal calculation of HSCY3 cluster without CLMM, but need to change colossus dependency because it is not easy to install on NERSC

* Finished baseline documentation, including changing colossus cosmology dependency in notebook to the astropy one so this is easier to run on NERSC

* minor change to clarify sections of notebook

* added kwargs to GalaxyCluster instance definition in preparation for re-installing latest CLMM with Caio's added coordinate_system kwargs

* Updated logic for lensing angle conversion between coordinate systems in _compute_lensing_angles_flatsky and updated tests

* Revert "Updated logic for lensing angle conversion between coordinate systems in _compute_lensing_angles_flatsky and updated tests"

This reverts commit 4a1faa6.

* Added coordinate_system validation and extra tests

* Changed example notebook to document new coordinate_system option

* examples/test_coordinate.ipynb has additional minor markdown detail

* test_coordinate.ipynb now runs from top to bottom using Caio's coordinate system implementation!

* adding additional docstrings to Tomomi's from-scratch calculation of lensing from HSC data

* refactoring code into functions to make loop over cluster lenses  more readable and some renaming of variables, e.g. sum to profile_sum, to avoid name space problems

* made additional refactoring changes, but refactored functions to calculate angles between source and lens, etc. likely broke something in the background selection (now empty)

* some of the refactoring incorporated with pre-broken code

* cleaned up the loop over rbins

* In line comments for portions of calculation

* modified reverted commit to when the functions did not break, added in documentation and light refactoring from latest commit

* renamed the notebook for consistency

* docs/doc-config.ini now includes the demo_coordinate_system notebook

* feat: Add coordinate_system parameter to compute_tangential_and_cross_components and _compute_lensing_angles functions (#624)

* feat: Add coordinate_system parameter to compute_tangential_and_cross_components and _compute_lensing_angles functions

* Update documentation to account for new coordinate_system option

* feat: Add coordinate_system conversion test to test_compute_lensing_angles_flatsky function

* Add coordinate_system conversion test to test_compute_lensing_angles_astropy function and fix bug in coordinate system conversion bug in compute_lensing_angles_astropy

* Set coordinate_system option during creation of GalaxyCluster object

* Removed debuggin print in test_dataops.py

* Fixed typo and set default coordinate_system to "pixel"

* Added option to choose coordinate system for generated mock catalog

* Added ellipticity coordinate system conversion tests to test_galaxycluster.py and test_mockdata.py

* Fixed formatting

* Updated logic for lensing angle conversion between coordinate systems in _compute_lensing_angles_flatsky and updated tests

* Revert "Updated logic for lensing angle conversion between coordinate systems in _compute_lensing_angles_flatsky and updated tests"

This reverts commit 4a1faa6.

* Added coordinate_system validation and extra tests

* Changed example notebook to document new coordinate_system option

* Fixed all the documentation for coordinate_system and changed names from 'pixel'/'sky' to 'euclidean'/'celestial'

* Added reference for defitions of coordinate systems

* Fixed bug in coordinate system conversion in mock data generation

* Test ValueError raise for coordinate_system in test_mockdata.py

* Added more explanations about ellipticity coordinate system

* Fixed typo

* uodated tag to 1.12.4

---------

Co-authored-by: Marina Ricci <[email protected]>

* removed a character in a markdown cell that tests complained about in making docs

* swapped pixel/euclidean and sky/celestial in notebook

* reverted two files to try to match main

* removed outputs in the notebook

* removed OTHER notebook outputs

* remove empty cells in notebooks

* made minor edits in response to review, primarily with generalizing file paths and removing comments or redundant text in the markdown

* incorporating original demo_mock_cluster.ipynb from main to remove changes to the file in this branch that should not have been committed

* modified the Oguri example to also show incorrect coordinate assumption as noted by Caio

* got rid of dollar signs inside markdown code snippet env hoping this will get the checks passed

* added review contributions line :-)

* added a note for the CosmoDC2 clusters so the user is aware to not necessarily expect a strong signal in center regions

* removed extra cell at end

* removed rogue savefig

* clarified why there might be less signal in the TXPipe outputted CosmoDC2 thing

* Formatted demo_coordinate_system_datasets.ipynb notebook

---------

Co-authored-by: Caio Lima de Oliveira <[email protected]>
Co-authored-by: Camille Avestruz <[email protected]>
Co-authored-by: Marina Ricci <[email protected]>
@rancesol rancesol marked this pull request as ready for review July 29, 2024 13:45
@combet
Copy link
Collaborator

combet commented Jan 15, 2025

Hi - I was looking at this branch as I was attempting to summarize all the new function names/functionalities for the v2.0 paper.

I understand that the main function for the prediction of the quadrupole components is in eval_excess_surface_density_triaxial in parent_class.py in the theory module. However, I do not see a corresponding compute_excess_surface_density_triaxial function in the functional interface (func_layer.py).

If memory serves, the theory module was originally designed to have a “mirror” implementation in the functional interface (func.py) and in the object-oriented interface (parent_class.py). See e.g, the 2 theory demo notebooks (eval_* methods of the CLMM modeling class all have a corresponding compute_* function in the functional interface). I'd be tempted to say we should try to keep this when developing new functionalities. What do you think? @shenmingfu, @rancesol, @tae-h-shin, @rkrishnan2912, @m-aguena, @marina-ricci

Comment on lines 128 to 129
If `True`, the quadrupole shear components (g_4theta, g_const; Shin+2018) are calculated
instead of g_t and g_x
Copy link
Collaborator

@combet combet Jan 15, 2025

Choose a reason for hiding this comment

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

From what I see in the code, that case returns the quadrupole components as well as g_t, g_x, not instead. Or I am missing something?

Copy link
Collaborator

Choose a reason for hiding this comment

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

You are correct. I remember this was a last minute change -- we just forgot to edit the description. Thanks for catching that!

@rancesol
Copy link
Collaborator

Hi @combet , I agree on the naming scheme between the parent_class and func_layer. We had ensured that functionally they were identical but how they are called differs. We will correct this as soon as possible.

@rancesol
Copy link
Collaborator

Hi @combet, thanks for the comments. They've both been resolved now.

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.

8 participants