-
Notifications
You must be signed in to change notification settings - Fork 45
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #352 from wines1/main
Updating CHIPS-FF Benchmarks
- Loading branch information
Showing
308 changed files
with
1,608 additions
and
70,544 deletions.
There are no files selected for viewing
Binary file modified
BIN
-447 Bytes
(69%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_a.json.zip
Binary file not shown.
Binary file modified
BIN
-444 Bytes
(69%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_b.json.zip
Binary file not shown.
Binary file modified
BIN
-438 Bytes
(70%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_c.json.zip
Binary file not shown.
Binary file modified
BIN
-440 Bytes
(66%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_c11.json.zip
Binary file not shown.
Binary file modified
BIN
-450 Bytes
(65%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_c44.json.zip
Binary file not shown.
Binary file modified
BIN
-456 Bytes
(67%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_form_en.json.zip
Binary file not shown.
Binary file modified
BIN
-427 Bytes
(68%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_kv.json.zip
Binary file not shown.
Binary file modified
BIN
+54 Bytes
(100%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_surf_en.json.zip
Binary file not shown.
Binary file modified
BIN
-52 Bytes
(93%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_vac_en.json.zip
Binary file not shown.
Binary file modified
BIN
-436 Bytes
(79%)
jarvis_leaderboard/benchmarks/AI/SinglePropertyPrediction/dft_3d_chipsff_vol.json.zip
Binary file not shown.
Binary file added
BIN
+1 KB
...ard/contributions/alignn_ff/AI-SinglePropertyPrediction-a-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file added
BIN
+1.01 KB
...ard/contributions/alignn_ff/AI-SinglePropertyPrediction-b-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file added
BIN
+1004 Bytes
...ard/contributions/alignn_ff/AI-SinglePropertyPrediction-c-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file added
BIN
+1.59 KB
...d/contributions/alignn_ff/AI-SinglePropertyPrediction-c11-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file added
BIN
+1.61 KB
...d/contributions/alignn_ff/AI-SinglePropertyPrediction-c44-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file added
BIN
+1.6 KB
...ntributions/alignn_ff/AI-SinglePropertyPrediction-form_en-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file added
BIN
+1.54 KB
...rd/contributions/alignn_ff/AI-SinglePropertyPrediction-kv-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file added
BIN
+1.43 KB
...ntributions/alignn_ff/AI-SinglePropertyPrediction-surf_en-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file added
BIN
+960 Bytes
...ontributions/alignn_ff/AI-SinglePropertyPrediction-vac_en-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file added
BIN
+1.59 KB
...d/contributions/alignn_ff/AI-SinglePropertyPrediction-vol-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
File renamed without changes.
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
298 changes: 298 additions & 0 deletions
298
jarvis_leaderboard/contributions/alignn_ff/run_chipsff.py
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 |
---|---|---|
@@ -0,0 +1,298 @@ | ||
#!/usr/bin/env python | ||
import os | ||
import pandas as pd | ||
import plotly.express as px | ||
import argparse | ||
from jarvis.db.jsonutils import loadjson | ||
from chipsff.config import CHIPSFFConfig | ||
from tqdm import tqdm | ||
from chipsff.general_material_analyzer import MaterialsAnalyzer | ||
from chipsff.alignn_ff_db_analyzer import AlignnFFForcesAnalyzer | ||
from chipsff.mlearn_db_analyzer import MLearnForcesAnalyzer | ||
from chipsff.mptraj_analyzer import MPTrjAnalyzer | ||
from chipsff.scaling_analyzer import ScalingAnalyzer | ||
|
||
|
||
def analyze_multiple_structures( | ||
jid_list, calculator_types, chemical_potentials_file, **kwargs | ||
): | ||
""" | ||
Analyzes multiple structures with multiple calculators and aggregates error metrics. | ||
Args: | ||
jid_list (List[str]): List of JIDs to analyze. | ||
calculator_types (List[str]): List of calculator types to use. | ||
chemical_potentials_file (str): Path to the chemical potentials JSON file. | ||
**kwargs: Additional keyword arguments for analysis settings. | ||
Returns: | ||
None | ||
""" | ||
composite_error_data = {} | ||
|
||
for calculator_type in calculator_types: | ||
# List to store individual error DataFrames | ||
error_dfs = [] | ||
|
||
for jid in tqdm(jid_list, total=len(jid_list)): | ||
print(f"Analyzing {jid} with {calculator_type}...") | ||
# Fetch calculator-specific settings | ||
calc_settings = kwargs.get("calculator_settings", {}).get( | ||
calculator_type, {} | ||
) | ||
analyzer = MaterialsAnalyzer( | ||
jid=jid, | ||
calculator_type=calculator_type, | ||
chemical_potentials_file=chemical_potentials_file, | ||
bulk_relaxation_settings=kwargs.get( | ||
"bulk_relaxation_settings" | ||
), | ||
phonon_settings=kwargs.get("phonon_settings"), | ||
properties_to_calculate=kwargs.get("properties_to_calculate"), | ||
use_conventional_cell=kwargs.get( | ||
"use_conventional_cell", False | ||
), | ||
surface_settings=kwargs.get("surface_settings"), | ||
defect_settings=kwargs.get("defect_settings"), | ||
phonon3_settings=kwargs.get("phonon3_settings"), | ||
md_settings=kwargs.get("md_settings"), | ||
calculator_settings=calc_settings, # Pass calculator-specific settings | ||
) | ||
# Run analysis and get error data | ||
error_dat = analyzer.run_all() | ||
error_df = pd.DataFrame([error_dat]) | ||
error_dfs.append(error_df) | ||
|
||
# Concatenate all error DataFrames | ||
all_errors_df = pd.concat(error_dfs, ignore_index=True) | ||
|
||
# Compute composite errors by ignoring NaN values | ||
composite_error = all_errors_df.mean(skipna=True).to_dict() | ||
|
||
# Store the composite error data for this calculator type | ||
composite_error_data[calculator_type] = composite_error | ||
|
||
# Once all materials and calculators have been processed, create a DataFrame | ||
composite_df = pd.DataFrame(composite_error_data).transpose() | ||
|
||
# Plot the composite scorecard | ||
plot_composite_scorecard(composite_df) | ||
|
||
# Save the composite dataframe | ||
composite_df.to_csv("composite_error_data.csv", index=True) | ||
|
||
|
||
def analyze_multiple_interfaces( | ||
film_jid_list, | ||
substrate_jid_list, | ||
calculator_types, | ||
chemical_potentials_file, | ||
film_index="1_1_0", | ||
substrate_index="1_1_0", | ||
): | ||
for calculator_type in calculator_types: | ||
for film_jid in film_jid_list: | ||
for substrate_jid in substrate_jid_list: | ||
print( | ||
f"Analyzing interface between {film_jid} and {substrate_jid} with {calculator_type}..." | ||
) | ||
analyzer = MaterialsAnalyzer( | ||
calculator_type=calculator_type, | ||
chemical_potentials_file=chemical_potentials_file, | ||
film_jid=film_jid, | ||
substrate_jid=substrate_jid, | ||
film_index=film_index, | ||
substrate_index=substrate_index, | ||
) | ||
analyzer.analyze_interfaces() | ||
|
||
|
||
def plot_composite_scorecard(df): | ||
|
||
fig = px.imshow( | ||
df, text_auto=True, aspect="auto", labels=dict(color="Error") | ||
) | ||
|
||
# Update layout for larger font sizes | ||
fig.update_layout( | ||
font=dict(size=24), # Adjust the font size | ||
coloraxis_colorbar=dict( | ||
title_font=dict(size=18), tickfont=dict(size=18) | ||
), | ||
) | ||
|
||
# Optionally adjust the text font size for cells | ||
fig.update_traces(textfont=dict(size=18)) # Adjust text size in cells | ||
fname_plot = "composite_error_scorecard.png" | ||
fig.write_image(fname_plot) | ||
fig.show() | ||
|
||
|
||
# Ensure that the necessary modules and functions are imported | ||
# from your existing codebase, such as `data`, `Atoms`, `voigt_6_to_full_3x3_stress`, etc. | ||
# Example: | ||
# from your_module import data, Atoms, voigt_6_to_full_3x3_stress, loadjson | ||
|
||
|
||
def main(): | ||
import pprint | ||
|
||
parser = argparse.ArgumentParser(description="Run Materials Analyzer") | ||
parser.add_argument( | ||
"--input_file", | ||
default="input.json", | ||
type=str, | ||
help="Path to the input configuration JSON file", | ||
) | ||
args = parser.parse_args() | ||
|
||
input_file = loadjson(args.input_file) | ||
input_file_data = CHIPSFFConfig(**input_file) | ||
pprint.pprint(input_file_data.dict()) | ||
|
||
# Check if scaling test is requested | ||
if input_file_data.scaling_test: | ||
print("Running scaling test...") | ||
scaling_analyzer = ScalingAnalyzer(input_file_data) | ||
scaling_analyzer.run() | ||
else: | ||
# Determine the list of JIDs | ||
if input_file_data.jid: | ||
jid_list = [input_file_data.jid] | ||
elif input_file_data.jid_list: | ||
jid_list = input_file_data.jid_list | ||
else: | ||
jid_list = [] | ||
|
||
# Determine the list of calculators | ||
if input_file_data.calculator_type: | ||
calculator_list = [input_file_data.calculator_type] | ||
elif input_file_data.calculator_types: | ||
calculator_list = input_file_data.calculator_types | ||
else: | ||
calculator_list = [] | ||
|
||
# Handle film and substrate IDs for interface analysis | ||
film_jids = input_file_data.film_id if input_file_data.film_id else [] | ||
substrate_jids = ( | ||
input_file_data.substrate_id | ||
if input_file_data.substrate_id | ||
else [] | ||
) | ||
|
||
# Scenario 5: Batch Processing for Multiple JIDs and Calculators | ||
if input_file_data.jid_list and input_file_data.calculator_types: | ||
analyze_multiple_structures( | ||
jid_list=input_file_data.jid_list, | ||
calculator_types=input_file_data.calculator_types, | ||
chemical_potentials_file=input_file_data.chemical_potentials_file, | ||
bulk_relaxation_settings=input_file_data.bulk_relaxation_settings, | ||
phonon_settings=input_file_data.phonon_settings, | ||
properties_to_calculate=input_file_data.properties_to_calculate, | ||
use_conventional_cell=input_file_data.use_conventional_cell, | ||
surface_settings=input_file_data.surface_settings, | ||
defect_settings=input_file_data.defect_settings, | ||
phonon3_settings=input_file_data.phonon3_settings, | ||
md_settings=input_file_data.md_settings, | ||
calculator_settings=input_file_data.calculator_settings, # Pass calculator-specific settings | ||
) | ||
else: | ||
# Scenario 1 & 3: Single or Multiple JIDs with Single or Multiple Calculators | ||
if jid_list and tqdm(calculator_list, total=len(calculator_list)): | ||
for jid in tqdm(jid_list, total=len(jid_list)): | ||
for calculator_type in calculator_list: | ||
print(f"Analyzing {jid} with {calculator_type}...") | ||
# Fetch calculator-specific settings | ||
calc_settings = ( | ||
input_file_data.calculator_settings.get( | ||
calculator_type, {} | ||
) | ||
) | ||
analyzer = MaterialsAnalyzer( | ||
jid=jid, | ||
calculator_type=calculator_type, | ||
chemical_potentials_file=input_file_data.chemical_potentials_file, | ||
bulk_relaxation_settings=input_file_data.bulk_relaxation_settings, | ||
phonon_settings=input_file_data.phonon_settings, | ||
properties_to_calculate=input_file_data.properties_to_calculate, | ||
use_conventional_cell=input_file_data.use_conventional_cell, | ||
surface_settings=input_file_data.surface_settings, | ||
defect_settings=input_file_data.defect_settings, | ||
phonon3_settings=input_file_data.phonon3_settings, | ||
md_settings=input_file_data.md_settings, | ||
calculator_settings=calc_settings, # Pass calculator-specific settings | ||
) | ||
analyzer.run_all() | ||
|
||
# Proceed with other scenarios that don't overlap with jid_list and calculator_types | ||
# Scenario 2 & 4: Interface Calculations (Multiple Calculators and/or JIDs) | ||
if film_jids and substrate_jids and calculator_list: | ||
for film_jid, substrate_jid in zip(film_jids, substrate_jids): | ||
for calculator_type in calculator_list: | ||
print( | ||
f"Analyzing interface between {film_jid} and {substrate_jid} with {calculator_type}..." | ||
) | ||
# Fetch calculator-specific settings | ||
calc_settings = input_file_data.calculator_settings.get( | ||
calculator_type, {} | ||
) | ||
analyzer = MaterialsAnalyzer( | ||
calculator_type=calculator_type, | ||
chemical_potentials_file=input_file_data.chemical_potentials_file, | ||
film_jid=film_jid, | ||
substrate_jid=substrate_jid, | ||
film_index=input_file_data.film_index, | ||
substrate_index=input_file_data.substrate_index, | ||
bulk_relaxation_settings=input_file_data.bulk_relaxation_settings, | ||
phonon_settings=input_file_data.phonon_settings, | ||
properties_to_calculate=input_file_data.properties_to_calculate, | ||
calculator_settings=calc_settings, # Pass calculator-specific settings | ||
) | ||
analyzer.analyze_interfaces() | ||
|
||
# Continue with other independent scenarios | ||
# Scenario 6: MLearn Forces Comparison | ||
if input_file_data.mlearn_elements and input_file_data.calculator_type: | ||
print( | ||
f"Running mlearn forces comparison for elements {input_file_data.mlearn_elements} with {input_file_data.calculator_type}..." | ||
) | ||
mlearn_analyzer = MLearnForcesAnalyzer( | ||
calculator_type=input_file_data.calculator_type, | ||
mlearn_elements=input_file_data.mlearn_elements, | ||
calculator_settings=input_file_data.calculator_settings.get( | ||
input_file_data.calculator_type, {} | ||
), | ||
) | ||
mlearn_analyzer.run() | ||
|
||
# Scenario 7: AlignnFF Forces Comparison | ||
if input_file_data.alignn_ff_db and input_file_data.calculator_type: | ||
print( | ||
f"Running AlignnFF forces comparison with {input_file_data.calculator_type}..." | ||
) | ||
alignn_ff_analyzer = AlignnFFForcesAnalyzer( | ||
calculator_type=input_file_data.calculator_type, | ||
num_samples=input_file_data.num_samples, | ||
calculator_settings=input_file_data.calculator_settings.get( | ||
input_file_data.calculator_type, {} | ||
), | ||
) | ||
alignn_ff_analyzer.run() | ||
|
||
# Scenario 8: MPTrj Forces Comparison | ||
if input_file_data.mptrj and input_file_data.calculator_type: | ||
print( | ||
f"Running MPTrj forces comparison with {input_file_data.calculator_type}..." | ||
) | ||
mptrj_analyzer = MPTrjAnalyzer( | ||
calculator_type=input_file_data.calculator_type, | ||
num_samples=input_file_data.num_samples, | ||
calculator_settings=input_file_data.calculator_settings.get( | ||
input_file_data.calculator_type, {} | ||
), | ||
) | ||
mptrj_analyzer.run() | ||
|
||
|
||
if __name__ == "__main__": | ||
main() |
Binary file removed
BIN
-1.05 KB
...ributions/alignn_ff_12_2_24/AI-SinglePropertyPrediction-a-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file removed
BIN
-1.05 KB
...ributions/alignn_ff_12_2_24/AI-SinglePropertyPrediction-b-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file removed
BIN
-1.02 KB
...ributions/alignn_ff_12_2_24/AI-SinglePropertyPrediction-c-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file removed
BIN
-1.45 KB
...butions/alignn_ff_12_2_24/AI-SinglePropertyPrediction-c11-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file removed
BIN
-1.48 KB
...butions/alignn_ff_12_2_24/AI-SinglePropertyPrediction-c44-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file removed
BIN
-1.48 KB
...ons/alignn_ff_12_2_24/AI-SinglePropertyPrediction-form_en-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file removed
BIN
-1.46 KB
...ibutions/alignn_ff_12_2_24/AI-SinglePropertyPrediction-kv-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file removed
BIN
-936 Bytes
...ons/alignn_ff_12_2_24/AI-SinglePropertyPrediction-surf_en-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file removed
BIN
-690 Bytes
...ions/alignn_ff_12_2_24/AI-SinglePropertyPrediction-vac_en-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
Binary file removed
BIN
-1.26 KB
...butions/alignn_ff_12_2_24/AI-SinglePropertyPrediction-vol-dft_3d_chipsff-test-mae.csv.zip
Binary file not shown.
15 changes: 0 additions & 15 deletions
15
jarvis_leaderboard/contributions/alignn_ff_12_2_24/metadata.json
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.