generated from gwnrtools/gwnrtools
-
Notifications
You must be signed in to change notification settings - Fork 6
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
Separate simulation metadata from (sxs) metadata #64
Open
SSL32081
wants to merge
5
commits into
gwnrtools:master
Choose a base branch
from
SSL32081:fix_metadata
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from 3 commits
Commits
Show all changes
5 commits
Select commit
Hold shift + click to select a range
dedc55a
Convert metadata to dict when possible.
SSL32081 f3c6aea
Distinguish metadata from sim_metadata.
SSL32081 92570fd
Correct reference to self.sim_metadata.
SSL32081 2dc1d8f
Remove commented lines.
SSL32081 718cfad
Merge branch 'master' into fix_metadata
SSL32081 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -116,9 +116,9 @@ def load_from_h5(cls, file_path_or_open_file, metadata={}, verbosity=0): | |
# it here. | ||
|
||
try: | ||
cls._metadata | ||
cls._sim_metadata | ||
except AttributeError: | ||
cls._metadata = metadata | ||
cls._sim_metadata = metadata | ||
|
||
ELL_MIN, ELL_MAX = 2, 10 | ||
ell_min, ell_max = 99, -1 | ||
|
@@ -165,7 +165,7 @@ def load_from_h5(cls, file_path_or_open_file, metadata={}, verbosity=0): | |
data[:, idx] = amp_interp(times) * np.exp(1j * phase_interp(times)) | ||
|
||
w_attributes = {} | ||
w_attributes["metadata"] = metadata | ||
# w_attributes["metadata"] = metadata | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. No need to comment this line out, please remove it entirely. Please also remove the other commented out # w_attribute below. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Sure, just did. |
||
w_attributes["history"] = "" | ||
w_attributes["frame"] = quaternionic.array([[1.0, 0.0, 0.0, 0.0]]) | ||
w_attributes["frame_type"] = "inertial" | ||
|
@@ -202,17 +202,17 @@ def filepath(self): | |
@property | ||
def sim_metadata(self): | ||
"""Return the simulation metadata dictionary""" | ||
return self._metadata["metadata"] | ||
return self._sim_metadata | ||
|
||
@property | ||
def metadata(self): | ||
"""Return the simulation metadata dictionary""" | ||
return self.sim_metadata | ||
return self._metadata | ||
|
||
@property | ||
def label(self): | ||
"""Return a Latex label that summarizes key simulation details""" | ||
md = self.metadata | ||
md = self.sim_metadata | ||
|
||
return ( | ||
f"$q{md['relaxed_mass_ratio_1_over_2']:0.3f}\\_" | ||
|
@@ -243,7 +243,7 @@ def get_parameters(self, total_mass=1.0): | |
dict: Initial binary parameters with names compatible with PyCBC. | ||
""" | ||
|
||
metadata = self.metadata | ||
metadata = self.sim_metadata | ||
parameters = md.get_source_parameters_from_metadata( | ||
metadata, total_mass=total_mass | ||
) | ||
|
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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.
I am confused why this check is needed. Wouldn't
metadata
before and after this action be the same thing?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.
This is just a quick fix for another small issue. Tbh, I think it could be addressed more appropriately from the
sxs
side.The issue is that somehow the type of
metadata
becomes thesxs.Metadata
, and theupdate
method of which supports syntax like:metadata.update(new_meta)
, but notmetadata.update(**new_data)
.But then the latter syntax is used in here. Since I am not sure whether
sxs
expects themetadata
there has to be a puredict
or that they are not aware of this issue, I opt for this simple fix here.Going back to the original question, the
sxs.Metadata
is a subclass fromOrderedDict
, so theisinstance
anditems()
methods work, and converting it to a simpledict
revert theupdate
method back to the usual one.