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

graph building and file I/O with Xtals.jl #112

Merged
merged 19 commits into from
Sep 7, 2021
Merged

graph building and file I/O with Xtals.jl #112

merged 19 commits into from
Sep 7, 2021

Conversation

rkurchin
Copy link
Member

Prerequisite for #10 but won't resolve it on its own. Will also help #111 go more smoothly.

Need to actually implement the neighbor list function, which will be the most intensive part of this. Not really started yet, but I have a clear picture of how it will go and it's sketched out in some comments...

If this ends up working well, I may just PR that function to Xtals.jl as it could definitely be useful for others, but going to play with it here for now.

Signed off by Rachel Kurchin [email protected]
src/utils/graph_building.jl Outdated Show resolved Hide resolved
src/utils/graph_building.jl Outdated Show resolved Hide resolved
@codecov-commenter
Copy link

codecov-commenter commented Aug 23, 2021

Codecov Report

Merging #112 (8b6d05e) into main (4565893) will increase coverage by 0.44%.
The diff coverage is 100.00%.

Impacted file tree graph

@@            Coverage Diff             @@
##             main     #112      +/-   ##
==========================================
+ Coverage   86.97%   87.42%   +0.44%     
==========================================
  Files          17       17              
  Lines         476      493      +17     
==========================================
+ Hits          414      431      +17     
  Misses         62       62              
Impacted Files Coverage Δ
src/atoms/atomgraph.jl 77.27% <100.00%> (+1.08%) ⬆️
src/utils/graph_building.jl 98.36% <100.00%> (+0.48%) ⬆️

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 4565893...8b6d05e. Read the comment docs.

src/utils/graph_building.jl Outdated Show resolved Hide resolved
src/utils/graph_building.jl Outdated Show resolved Hide resolved
src/utils/graph_building.jl Outdated Show resolved Hide resolved
src/utils/graph_building.jl Outdated Show resolved Hide resolved
src/utils/graph_building.jl Outdated Show resolved Hide resolved
src/utils/graph_building.jl Outdated Show resolved Hide resolved
Signed-off-by: Rachel Kurchin <[email protected]>
More details:
* Made separate dispatch of build_graph function onto a Crystal object; this should be directly usable as the first layer in a model and differentiate with respect to c.atoms.coords.xf (or convert to Cartesian first)
* ASE dependency is no more! The cost of this was loss of compatibility with some structure file formats. Some of these (most notably XYZ) will be recoverable with a pymatgen update.
* I removed the normalize_weights option, because I can't conceive of a case where you wouldn't want to do this
* I also removed the test for nonperiodicity because I realized this is not generally stored in the structure files but rather in the ASE Atoms object (which has certain defaults when reading in files), so it wasn't an actual information stream

Signed off by Rachel Kurchin [email protected] 25 August 2021
Signed-off-by: Rachel Kurchin <[email protected]>
@rkurchin rkurchin marked this pull request as ready for review August 27, 2021 18:42
@rkurchin rkurchin requested a review from thazhemadam August 27, 2021 18:42
rkurchin and others added 4 commits August 28, 2021 14:23
Co-authored-by: Anant Thazhemadam <[email protected]>
…k for cutoff radius size, change from loops to list comprehensions for neighbor_list

Signed-off-by: Rachel Kurchin <[email protected]>
Signed-off-by: Rachel Kurchin <[email protected]>
src/utils/graph_building.jl Outdated Show resolved Hide resolved
src/utils/graph_building.jl Outdated Show resolved Hide resolved
src/utils/graph_building.jl Outdated Show resolved Hide resolved
rkurchin and others added 7 commits August 30, 2021 13:46
Signed-off-by: Rachel Kurchin <[email protected]>
Signed-off-by: Rachel Kurchin <[email protected]>
Signed-off-by: Rachel Kurchin <[email protected]>
Signed-off-by: Anant Thazhemadam <[email protected]>
… a better longterm solution though

Signed-off-by: Rachel Kurchin <[email protected]>
Signed-off-by: Rachel Kurchin <[email protected]>
@@ -58,7 +58,7 @@ using Xtals
ag2 = deserialize(abspath(@__DIR__, "..", "test_data", "strucs", "testgraph.jls"))
@test adjacency_matrix(ag.graph) == adjacency_matrix(ag2.graph)
@test elements(ag) == ag2.elements
@test Atoms.normalized_laplacian(ag) == ag2.laplacian
@test ChemistryFeaturization.Atoms.normalized_laplacian(ag) == ag2.laplacian
Copy link
Member

Choose a reason for hiding this comment

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

Could you please expand on what exactly the namespace conflict is? I don't recall seeing any such conflicts while testing with the OFD PR.

It might also help to actually make a note of it for future reference.

Copy link
Member Author

Choose a reason for hiding this comment

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

it's because Xtals also defines Atoms so while this worked before:

using ChemistryFeaturization.Atoms
# then later...
Atoms.whatever()

that's now ambiguous as to which Atoms it's referring to, so now I just have

using ChemistryFeaturization
# then later...
ChemistryFeaturization.Atoms.stuff...

Copy link
Member

Choose a reason for hiding this comment

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

Ah, I see. In that case, I can't think of any other long term solution that's better than what we have rn.

Copy link
Member Author

Choose a reason for hiding this comment

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

yeah I mean short of renaming our Atoms module to something else there isn't really another option

Project.toml Outdated Show resolved Hide resolved
Project.toml Show resolved Hide resolved
Project.toml Show resolved Hide resolved
src/atoms/atomgraph.jl Show resolved Hide resolved
- `max_num_nbr::Integer=12`: maximum number of neighbors to include (even if more fall within cutoff radius)
- `dist_decay_func::Function=inverse_square`: function to determine falloff of graph edge weights with neighbor distance
"""
function build_graph(
Copy link
Member

Choose a reason for hiding this comment

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

Could we have a reference to this docstring also under Utilities/Graph Building?

Copy link
Member Author

Choose a reason for hiding this comment

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

shouldn't the @autodocs do that?

Copy link
Member Author

Choose a reason for hiding this comment

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

I can't check right now because my local setup for building the docs is somehow broken again :/ but I thought the @autodocs block should do it?


Returns as is, js, dists to be compatible with ASE's output format for the analogous function.
"""
function neighbor_list(crys::Crystal; cutoff_radius::Real = 8.0)
Copy link
Member

Choose a reason for hiding this comment

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

Again, can we have a reference to this docstring in the docs? 😄

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