Files
Atomizer/interactive_setup_output.txt
Anto01 2f3afc3813 feat: Add substudy system with live history tracking and workflow fixes
Major Features:
- Hierarchical substudy system (like NX Solutions/Subcases)
  * Shared model files across all substudies
  * Independent configuration per substudy
  * Continuation support from previous substudies
  * Real-time incremental history updates
- Live history tracking with optimization_history_incremental.json
- Complete bracket_displacement_maximizing study with substudy examples

Core Fixes:
- Fixed expression update workflow to pass design_vars through simulation_runner
  * Restored working NX journal expression update mechanism
  * OP2 timestamp verification instead of file deletion
  * Resolved issue where all trials returned identical objective values
- Fixed LLMOptimizationRunner to pass design variables to simulation runner
- Enhanced NXSolver with timestamp-based file regeneration verification

New Components:
- optimization_engine/llm_optimization_runner.py - LLM-driven optimization runner
- optimization_engine/optimization_setup_wizard.py - Phase 3.3 setup wizard
- studies/bracket_displacement_maximizing/ - Complete substudy example
  * run_substudy.py - Substudy runner with continuation
  * run_optimization.py - Standalone optimization runner
  * config/substudy_template.json - Template for new substudies
  * substudies/coarse_exploration/ - 20-trial coarse search
  * substudies/fine_tuning/ - 50-trial refinement (continuation example)
  * SUBSTUDIES_README.md - Complete substudy documentation

Technical Improvements:
- Incremental history saving after each trial (optimization_history_incremental.json)
- Expression update workflow: .prt update → NX journal receives values → geometry update → FEM update → solve
- Trial indexing fix in substudy result saving
- Updated README with substudy system documentation

Testing:
- Successfully ran 20-trial coarse_exploration substudy
- Verified different objective values across trials (workflow fix validated)
- Confirmed live history updates in real-time
- Tested shared model file usage across substudies

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-16 21:29:54 -05:00

531 lines
23 KiB
Plaintext

fatal: not a git repository (or any of the parent directories): .git
================================================================================
ATOMIZER - INTERACTIVE OPTIMIZATION SETUP
================================================================================
[Atomizer] Welcome to Atomizer! I'll help you set up your optimization.
[Atomizer] First, I need to know about your model files.
[User] I have a bracket model:
- Part file: tests\Bracket.prt
- Simulation file: tests\Bracket_sim1.sim
[Atomizer] Great! Let me initialize the Setup Wizard to analyze your model...
================================================================================
STEP 1: MODEL INTROSPECTION
================================================================================
[Atomizer] I'm reading your NX model to find available design parameters...
[Atomizer] Found 4 expressions in your model:
- support_angle: 32.0 degrees
- tip_thickness: 24.0 mm
- p3: 10.0 mm
- support_blend_radius: 10.0 mm
[Atomizer] Which parameters would you like to use as design variables?
[User] I want to optimize tip_thickness and support_angle
[Atomizer] Perfect! Now, what's your optimization goal?
[User] I want to maximize displacement while keeping stress below
a safety factor of 4. The material is Aluminum 6061-T6.
================================================================================
STEP 2: BASELINE SIMULATION
================================================================================
[Atomizer] To validate your setup, I need to run ONE baseline simulation.
[Atomizer] This will generate an OP2 file that I can analyze to ensure
[Atomizer] the extraction pipeline will work correctly.
[Atomizer]
[Atomizer] Running baseline simulation with current parameter values...
[NX SOLVER] Starting simulation...
Input file: Bracket_sim1.sim
Working dir: tests
Mode: Journal
Deleted 3 old result file(s) to force fresh solve
[JOURNAL OUTPUT]
Mesh-Based Errors Summary
-------------------------
Total: 0 errors and 0 warnings
Material-Based Errors Summary
-----------------------------
Total: 0 errors and 0 warnings
Solution-Based Errors Summary
-----------------------------
Iterative Solver Option
More than 80 percent of the elements in this model are 3D elements.
It is therefore recommended that you turn ON the Element Iterative Solver in the "Edit
Solution" dialog.
Total: 0 errors and 0 warnings
Load/BC-Based Errors Summary
----------------------------
Total: 0 errors and 0 warnings
Nastran Model Setup Check completed
*** 20:33:59 ***
Starting Nastran Exporter
*** 20:33:59 ***
Writing file
c:\Users\antoi\Documents\Atomaste\Atomizer\tests\bracket_sim1-solution_1.dat
*** 20:33:59 ***
Writing SIMCENTER NASTRAN 2412.0 compatible deck
*** 20:33:59 ***
Writing Nastran System section
*** 20:33:59 ***
Writing File Management section
*** 20:33:59 ***
Writing Executive Control section
*** 20:33:59 ***
Writing Case Control section
*** 20:33:59 ***
Writing Bulk Data section
*** 20:33:59 ***
Writing Nodes
*** 20:33:59 ***
Writing Elements
*** 20:33:59 ***
Writing Physical Properties
*** 20:33:59 ***
Writing Materials
*** 20:33:59 ***
Writing Degree-of-Freedom Sets
*** 20:33:59 ***
Writing Loads and Constraints
*** 20:33:59 ***
Writing Coordinate Systems
*** 20:33:59 ***
Validating Solution Setup
*** 20:33:59 ***
Summary of Bulk Data cards written
+----------+----------+
| NAME | NUMBER |
+----------+----------+
| CHEXA | 306 |
| CPENTA | 10 |
| FORCE | 3 |
| GRID | 585 |
| MAT1 | 1 |
| MATT1 | 1 |
| PARAM | 6 |
| PSOLID | 1 |
| SPC | 51 |
| TABLEM1 | 3 |
+----------+----------+
*** 20:33:59 ***
Nastran Deck Successfully Written
[JOURNAL] Opening simulation: c:\Users\antoi\Documents\Atomaste\Atomizer\tests\Bracket_sim1.sim
[JOURNAL] Checking for open parts...
[JOURNAL] Opening simulation fresh from disk...
[JOURNAL] STEP 1: Updating Bracket.prt geometry...
[JOURNAL] Rebuilding geometry with new expression values...
[JOURNAL] Bracket geometry updated (0 errors)
[JOURNAL] STEP 2: Opening Bracket_fem1.fem...
[JOURNAL] Updating FE Model...
[JOURNAL] FE Model updated with new geometry!
[JOURNAL] STEP 3: Switching back to sim part...
[JOURNAL] Switched back to sim part
[JOURNAL] Starting solve...
[JOURNAL] Solve submitted!
[JOURNAL] Solutions solved: -1779619210
[JOURNAL] Solutions failed: 32764
[JOURNAL] Solutions skipped: 1218183744
[JOURNAL] Saving simulation to ensure output files are written...
[JOURNAL] Save complete!
[JOURNAL ERRORS]
Journal execution results for c:\Users\antoi\Documents\Atomaste\Atomizer\tests\_temp_solve_journal.py...
Syntax errors:
Line 0: Traceback (most recent call last):
File "c:\Users\antoi\Documents\Atomaste\Atomizer\tests\_temp_solve_journal.py", line 247, in <module>
sys.exit(0 if success else 1)
[NX SOLVER] Waiting for solve to complete...
[NX SOLVER] Output files detected after 0.5s
[NX SOLVER] Complete in 4.3s
[NX SOLVER] Results: bracket_sim1-solution_1.op2
[Atomizer] Baseline simulation complete! OP2 file: bracket_sim1-solution_1.op2
================================================================================
STEP 3: OP2 INTROSPECTION
================================================================================
[Atomizer] Now I'll analyze the OP2 file to see what's actually in there...
DEBUG: op2.py:614 combine=True
DEBUG: op2.py:615 -------- reading op2 with read_mode=1 (array sizing) --------
INFO: op2_scalar.py:1960 op2_filename = 'tests\\bracket_sim1-solution_1.op2'
DEBUG: op2_reader.py:323 date = (11, 16, 25)
WARNING: version.py:88 nx version='2412' is not supported
DEBUG: op2_reader.py:403 mode='nx' version='2412'
DEBUG: op2_scalar.py:2173 table_name=b'IBULK' (explicit bulk data)
DEBUG: op2_scalar.py:2173 table_name=b'ICASE' (explicit case control)
DEBUG: op2_scalar.py:2173 table_name=b'CASECC' (case control)
DEBUG: op2_scalar.py:2173 table_name=b'PVT0' (PARAM cards)
DEBUG: op2_scalar.py:2173 table_name=b'GPL' (grid point list)
DEBUG: op2_scalar.py:2173 table_name=b'GPDT' (grid point locations)
DEBUG: op2_scalar.py:2173 table_name=b'EPT' (property cards)
DEBUG: op2_scalar.py:2173 table_name=b'MPT' (material cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM2' (element cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM3' (constraint cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM4' (load cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM1' (grid/coord cards)
DEBUG: op2_scalar.py:2173 table_name=b'BGPDT' (grid points in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'DIT' (TABLEx cards)
DEBUG: op2_scalar.py:2173 table_name=b'EQEXIN' (internal/external ids)
DEBUG: op2_reader.py:672 eqexin idata=(101, 585, 0, 0, 0, 0, 0)
DEBUG: op2_scalar.py:2173 table_name=b'OQG1' (spc/mpc forces)
DEBUG: op2_scalar.py:2173 table_name=b'BOUGV1' (g-set U in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'OES1' (linear stress)
DEBUG: oes.py:2840 numwide_real=193
DEBUG: oes.py:2840 numwide_real=151
DEBUG: op2.py:634 -------- reading op2 with read_mode=2 (array filling) --------
DEBUG: op2_reader.py:323 date = (11, 16, 25)
WARNING: version.py:88 nx version='2412' is not supported
DEBUG: op2_scalar.py:2173 table_name=b'IBULK' (explicit bulk data)
DEBUG: op2_scalar.py:2173 table_name=b'ICASE' (explicit case control)
DEBUG: op2_scalar.py:2173 table_name=b'CASECC' (case control)
DEBUG: op2_scalar.py:2173 table_name=b'PVT0' (PARAM cards)
DEBUG: op2_scalar.py:2173 table_name=b'GPL' (grid point list)
DEBUG: op2_scalar.py:2173 table_name=b'GPDT' (grid point locations)
DEBUG: op2_scalar.py:2173 table_name=b'EPT' (property cards)
DEBUG: op2_scalar.py:2173 table_name=b'MPT' (material cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM2' (element cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM3' (constraint cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM4' (load cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM1' (grid/coord cards)
DEBUG: op2_scalar.py:2173 table_name=b'BGPDT' (grid points in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'DIT' (TABLEx cards)
DEBUG: op2_scalar.py:2173 table_name=b'EQEXIN' (internal/external ids)
DEBUG: op2_reader.py:672 eqexin idata=(101, 585, 0, 0, 0, 0, 0)
DEBUG: op2_scalar.py:2173 table_name=b'OQG1' (spc/mpc forces)
DEBUG: op2_scalar.py:2173 table_name=b'BOUGV1' (g-set U in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'OES1' (linear stress)
DEBUG: oes.py:2840 numwide_real=193
DEBUG: oes.py:2840 numwide_real=151
DEBUG: op2.py:932 combine_results
DEBUG: op2.py:648 finished reading op2
[Atomizer] Here's what I found in your OP2 file:
- Element types with stress: CHEXA, CPENTA
- Available results: displacement, stress
- Number of elements: 0
- Number of nodes: 0
================================================================================
STEP 4: LLM-GUIDED CONFIGURATION
================================================================================
[Atomizer] Based on your goal and the OP2 contents, here's what I recommend:
[Atomizer]
[Atomizer] OBJECTIVE:
[Atomizer] - Maximize displacement (minimize negative displacement)
[Atomizer]
[Atomizer] EXTRACTIONS:
[Atomizer] - Extract displacement from OP2
[Atomizer] - Extract stress from CHEXA elements
[Atomizer] (I detected these element types in your model)
[Atomizer]
[Atomizer] CALCULATIONS:
[Atomizer] - Calculate safety factor: SF = 276 MPa / max_stress
[Atomizer] - Negate displacement for minimization
[Atomizer]
[Atomizer] CONSTRAINT:
[Atomizer] - Enforce SF >= 4.0 with penalty
[Atomizer]
[Atomizer] DESIGN VARIABLES:
[Atomizer] - tip_thickness: 24.0 mm (suggest range: 15-25 mm)
[Atomizer] - support_angle: 32.0 degrees (suggest range: 20-40 deg)
[User] That looks good! Let's use those ranges.
================================================================================
STEP 5: PIPELINE VALIDATION (DRY RUN)
================================================================================
[Atomizer] Before running 20-30 optimization trials, let me validate that
[Atomizer] EVERYTHING works correctly with your baseline OP2 file...
[Atomizer]
[Atomizer] Running dry-run validation...
DEBUG: op2.py:614 combine=True
DEBUG: op2.py:615 -------- reading op2 with read_mode=1 (array sizing) --------
INFO: op2_scalar.py:1960 op2_filename = 'tests\\bracket_sim1-solution_1.op2'
DEBUG: op2_reader.py:323 date = (11, 16, 25)
WARNING: version.py:88 nx version='2412' is not supported
DEBUG: op2_reader.py:403 mode='nx' version='2412'
DEBUG: op2_scalar.py:2173 table_name=b'IBULK' (explicit bulk data)
DEBUG: op2_scalar.py:2173 table_name=b'ICASE' (explicit case control)
DEBUG: op2_scalar.py:2173 table_name=b'CASECC' (case control)
DEBUG: op2_scalar.py:2173 table_name=b'PVT0' (PARAM cards)
DEBUG: op2_scalar.py:2173 table_name=b'GPL' (grid point list)
DEBUG: op2_scalar.py:2173 table_name=b'GPDT' (grid point locations)
DEBUG: op2_scalar.py:2173 table_name=b'EPT' (property cards)
DEBUG: op2_scalar.py:2173 table_name=b'MPT' (material cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM2' (element cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM3' (constraint cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM4' (load cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM1' (grid/coord cards)
DEBUG: op2_scalar.py:2173 table_name=b'BGPDT' (grid points in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'DIT' (TABLEx cards)
DEBUG: op2_scalar.py:2173 table_name=b'EQEXIN' (internal/external ids)
DEBUG: op2_reader.py:672 eqexin idata=(101, 585, 0, 0, 0, 0, 0)
DEBUG: op2_scalar.py:2173 table_name=b'OQG1' (spc/mpc forces)
DEBUG: op2_scalar.py:2173 table_name=b'BOUGV1' (g-set U in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'OES1' (linear stress)
DEBUG: oes.py:2840 numwide_real=193
DEBUG: oes.py:2840 numwide_real=151
DEBUG: op2.py:634 -------- reading op2 with read_mode=2 (array filling) --------
DEBUG: op2_reader.py:323 date = (11, 16, 25)
WARNING: version.py:88 nx version='2412' is not supported
DEBUG: op2_scalar.py:2173 table_name=b'IBULK' (explicit bulk data)
DEBUG: op2_scalar.py:2173 table_name=b'ICASE' (explicit case control)
DEBUG: op2_scalar.py:2173 table_name=b'CASECC' (case control)
DEBUG: op2_scalar.py:2173 table_name=b'PVT0' (PARAM cards)
DEBUG: op2_scalar.py:2173 table_name=b'GPL' (grid point list)
DEBUG: op2_scalar.py:2173 table_name=b'GPDT' (grid point locations)
DEBUG: op2_scalar.py:2173 table_name=b'EPT' (property cards)
DEBUG: op2_scalar.py:2173 table_name=b'MPT' (material cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM2' (element cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM3' (constraint cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM4' (load cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM1' (grid/coord cards)
DEBUG: op2_scalar.py:2173 table_name=b'BGPDT' (grid points in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'DIT' (TABLEx cards)
DEBUG: op2_scalar.py:2173 table_name=b'EQEXIN' (internal/external ids)
DEBUG: op2_reader.py:672 eqexin idata=(101, 585, 0, 0, 0, 0, 0)
DEBUG: op2_scalar.py:2173 table_name=b'OQG1' (spc/mpc forces)
DEBUG: op2_scalar.py:2173 table_name=b'BOUGV1' (g-set U in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'OES1' (linear stress)
DEBUG: oes.py:2840 numwide_real=193
DEBUG: oes.py:2840 numwide_real=151
DEBUG: op2.py:932 combine_results
DEBUG: op2.py:648 finished reading op2
DEBUG: op2.py:614 combine=True
DEBUG: op2.py:615 -------- reading op2 with read_mode=1 (array sizing) --------
INFO: op2_scalar.py:1960 op2_filename = 'tests\\bracket_sim1-solution_1.op2'
DEBUG: op2_reader.py:323 date = (11, 16, 25)
Extraction failed: extract_solid_stress - No ctetra stress results in OP2
\u274c extract_solid_stress: No ctetra stress results in OP2
\u274c calculate_safety_factor: name 'max_von_mises' is not defined
Required input 'min_force' not found in context
Hook 'ratio_hook' failed: Missing required input: min_force
Traceback (most recent call last):
File "c:\Users\antoi\Documents\Atomaste\Atomizer\optimization_engine\plugins\hooks.py", line 72, in execute
result = self.function(context)
^^^^^^^^^^^^^^^^^^^^^^
File "c:\Users\antoi\Documents\Atomaste\Atomizer\optimization_engine\plugins\post_calculation\min_to_avg_ratio_hook.py", line 38, in ratio_hook
raise ValueError(f"Missing required input: min_force")
ValueError: Missing required input: min_force
Hook 'ratio_hook' failed: Missing required input: min_force
Required input 'max_stress' not found in context
Hook 'safety_factor_hook' failed: Missing required input: max_stress
Traceback (most recent call last):
File "c:\Users\antoi\Documents\Atomaste\Atomizer\optimization_engine\plugins\hooks.py", line 72, in execute
result = self.function(context)
^^^^^^^^^^^^^^^^^^^^^^
File "c:\Users\antoi\Documents\Atomaste\Atomizer\optimization_engine\plugins\post_calculation\safety_factor_hook.py", line 38, in safety_factor_hook
raise ValueError(f"Missing required input: max_stress")
ValueError: Missing required input: max_stress
Hook 'safety_factor_hook' failed: Missing required input: max_stress
Required input 'norm_stress' not found in context
Hook 'weighted_objective_hook' failed: Missing required input: norm_stress
Traceback (most recent call last):
File "c:\Users\antoi\Documents\Atomaste\Atomizer\optimization_engine\plugins\hooks.py", line 72, in execute
result = self.function(context)
^^^^^^^^^^^^^^^^^^^^^^
File "c:\Users\antoi\Documents\Atomaste\Atomizer\optimization_engine\plugins\post_calculation\weighted_objective_test.py", line 38, in weighted_objective_hook
raise ValueError(f"Missing required input: norm_stress")
ValueError: Missing required input: norm_stress
Hook 'weighted_objective_hook' failed: Missing required input: norm_stress
\u26a0\ufe0f No explicit objective, using: max_displacement
WARNING: version.py:88 nx version='2412' is not supported
DEBUG: op2_reader.py:403 mode='nx' version='2412'
DEBUG: op2_scalar.py:2173 table_name=b'IBULK' (explicit bulk data)
DEBUG: op2_scalar.py:2173 table_name=b'ICASE' (explicit case control)
DEBUG: op2_scalar.py:2173 table_name=b'CASECC' (case control)
DEBUG: op2_scalar.py:2173 table_name=b'PVT0' (PARAM cards)
DEBUG: op2_scalar.py:2173 table_name=b'GPL' (grid point list)
DEBUG: op2_scalar.py:2173 table_name=b'GPDT' (grid point locations)
DEBUG: op2_scalar.py:2173 table_name=b'EPT' (property cards)
DEBUG: op2_scalar.py:2173 table_name=b'MPT' (material cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM2' (element cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM3' (constraint cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM4' (load cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM1' (grid/coord cards)
DEBUG: op2_scalar.py:2173 table_name=b'BGPDT' (grid points in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'DIT' (TABLEx cards)
DEBUG: op2_scalar.py:2173 table_name=b'EQEXIN' (internal/external ids)
DEBUG: op2_reader.py:672 eqexin idata=(101, 585, 0, 0, 0, 0, 0)
DEBUG: op2_scalar.py:2173 table_name=b'OQG1' (spc/mpc forces)
DEBUG: op2_scalar.py:2173 table_name=b'BOUGV1' (g-set U in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'OES1' (linear stress)
DEBUG: oes.py:2840 numwide_real=193
DEBUG: oes.py:2840 numwide_real=151
DEBUG: op2.py:634 -------- reading op2 with read_mode=2 (array filling) --------
DEBUG: op2_reader.py:323 date = (11, 16, 25)
WARNING: version.py:88 nx version='2412' is not supported
DEBUG: op2_scalar.py:2173 table_name=b'IBULK' (explicit bulk data)
DEBUG: op2_scalar.py:2173 table_name=b'ICASE' (explicit case control)
DEBUG: op2_scalar.py:2173 table_name=b'CASECC' (case control)
DEBUG: op2_scalar.py:2173 table_name=b'PVT0' (PARAM cards)
DEBUG: op2_scalar.py:2173 table_name=b'GPL' (grid point list)
DEBUG: op2_scalar.py:2173 table_name=b'GPDT' (grid point locations)
DEBUG: op2_scalar.py:2173 table_name=b'EPT' (property cards)
DEBUG: op2_scalar.py:2173 table_name=b'MPT' (material cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM2' (element cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM3' (constraint cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM4' (load cards)
DEBUG: op2_scalar.py:2173 table_name=b'GEOM1' (grid/coord cards)
DEBUG: op2_scalar.py:2173 table_name=b'BGPDT' (grid points in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'DIT' (TABLEx cards)
DEBUG: op2_scalar.py:2173 table_name=b'EQEXIN' (internal/external ids)
DEBUG: op2_reader.py:672 eqexin idata=(101, 585, 0, 0, 0, 0, 0)
DEBUG: op2_scalar.py:2173 table_name=b'OQG1' (spc/mpc forces)
DEBUG: op2_scalar.py:2173 table_name=b'BOUGV1' (g-set U in cid=0 frame)
DEBUG: op2_scalar.py:2173 table_name=b'OES1' (linear stress)
DEBUG: oes.py:2840 numwide_real=193
DEBUG: oes.py:2840 numwide_real=151
DEBUG: op2.py:932 combine_results
DEBUG: op2.py:648 finished reading op2
[Wizard] VALIDATION RESULTS:
[Wizard] [OK] extractor: ['max_displacement', 'max_disp_node', 'max_disp_x', 'max_disp_y', 'max_disp_z']
[Wizard] [FAIL] extractor: No ctetra stress results in OP2
[Wizard] [FAIL] calculation: name 'max_von_mises' is not defined
[Wizard] [OK] calculation: Created ['neg_displacement']
[Wizard] [OK] hook: 3 results
[Wizard] [OK] objective: 0.36178338527679443
================================================================================
VALIDATION FAILED!
================================================================================
[Atomizer] The validation found issues that need to be fixed:
Traceback (most recent call last):
File "c:\Users\antoi\Documents\Atomaste\Atomizer\tests\interactive_optimization_setup.py", line 324, in <module>
main()
File "c:\Users\antoi\Documents\Atomaste\Atomizer\tests\interactive_optimization_setup.py", line 316, in main
print(f" [ERROR] {result.message}")
File "C:\Users\antoi\anaconda3\envs\test_env\Lib\encodings\cp1252.py", line 19, in encode
return codecs.charmap_encode(input,self.errors,encoding_table)[0]
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
UnicodeEncodeError: 'charmap' codec can't encode character '\u274c' in position 19: character maps to <undefined>