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

GUI - EVPFFT-SS #249

Open
wants to merge 38 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
d4156a2
minor change to ui
shankinsMechEng May 2, 2024
5c542fc
update submodule to match new commit reference
shankinsMechEng May 2, 2024
0866cef
Merge branch 'main' into GUI
shankinsMechEng May 2, 2024
8315b74
minor changes to UI
shankinsMechEng Jun 13, 2024
5a36d14
MAJOR UPDATE
shankinsMechEng Oct 15, 2024
e2cca95
added ability to do BATCH homogenization for different geometry files
shankinsMechEng Oct 17, 2024
835ccfe
added basic save/load functions to GUI (no visuals, just buttons)
shankinsMechEng Oct 18, 2024
3cd9bbc
fixed bugs with xdmf import and multi material homogenization run
shankinsMechEng Oct 18, 2024
ce7bd94
added ability to save/open GUI file
shankinsMechEng Oct 21, 2024
11bb92b
fixed some bugs with save/load feature
shankinsMechEng Oct 21, 2024
273f376
added visualization for LAFFT text files
shankinsMechEng Oct 22, 2024
612c658
added visualizations for Los Alamos FFT Writer
shankinsMechEng Oct 22, 2024
b9362c1
added capability for homogenizing polycrystalline materials using ela…
shankinsMechEng Oct 24, 2024
0d0f751
added generalized Bulk Forming solver routine into GUI
shankinsMechEng Oct 31, 2024
0ea65a9
bones for having general evpfft inputs to GUI
shankinsMechEng Nov 7, 2024
4c396c7
fully functioning bulk forming pipeline
shankinsMechEng Nov 8, 2024
99f7b5f
bug fix for dark mode
shankinsMechEng Nov 12, 2024
738171d
added ability for user to add custom slip system definition in GUI
shankinsMechEng Nov 12, 2024
8dc938c
added stl and vtk files to bulk forming pipeline
shankinsMechEng Nov 14, 2024
6fb9b66
added ability to import elastic and plastic input parameter files int…
shankinsMechEng Nov 14, 2024
7df12ca
partial add of button functionality to import legacy evpfft files. no…
shankinsMechEng Nov 15, 2024
fce295f
legacy evpfft input file complete for a single phase.
shankinsMechEng Nov 25, 2024
ecb586d
added ability to run batch job for .txt polycrystalline files
shankinsMechEng Dec 16, 2024
2fa85d8
updated homogenization and bulk forming solvers to handle new .pvtu o…
shankinsMechEng Dec 19, 2024
8aec665
fixed minor bug with opening a saved bulk forming simulation file
shankinsMechEng Dec 19, 2024
b31d8ef
added OMP flags to fix issue with .pvtu visualizations
shankinsMechEng Dec 20, 2024
7e82640
added ability to run evpfft solver with mpi ranks
shankinsMechEng Dec 23, 2024
50682c3
added convergence error warnings for evpfft solver
shankinsMechEng Dec 24, 2024
3f706b7
added deformation scale factor to evpfft solver. Note: if evpfft is r…
shankinsMechEng Jan 2, 2025
86fefea
added terminate button to evpfft solver
shankinsMechEng Jan 3, 2025
670516a
added new file option
shankinsMechEng Jan 3, 2025
7b26d1d
asks user about saving before GUI closes
shankinsMechEng Jan 3, 2025
61cca14
added ability to write input files
shankinsMechEng Jan 3, 2025
e5c1e50
made initial deformation scale factor to bee 10% of largest dimension
shankinsMechEng Jan 3, 2025
25b89f4
minor visualization bug fix
shankinsMechEng Jan 6, 2025
b3ce66e
Merge branch 'main' into GUI
shankinsMechEng Jan 6, 2025
f0de1f4
merged with main
shankinsMechEng Jan 6, 2025
d0e56b4
Large vs small strain evpfft option added. Updated graphics features.
shankinsMechEng Jan 21, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1,524 changes: 1,524 additions & 0 deletions python/FIERRO-GUI/fierro_gui/Bulk_Forming.py

Large diffs are not rendered by default.

184 changes: 184 additions & 0 deletions python/FIERRO-GUI/fierro_gui/Bulk_Forming_WInput.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,184 @@
import os
import tempfile

def Bulk_Forming_WInput(self):
# Plastic Input File
plastic_parameters = open(self.BULK_FORMING_PLASTIC_PARAMETERS,"w")
if self.TMaterials_2.item(0,23) is None or not self.TMaterials_2.item(0,23).text().strip():
no_plasticity_input = 'SLIP SYSTEMS FOR CUBIC CRYSTAL\n' \
'CUBIC icryst\n' \
' 1. 1. 1. crystal axis (cdim(i))\n' \
' 0 nmodesx (total # of modes listed in the file)\n' \
' 0 nmodes (# of modes to be used in the calculation)'
plastic_parameters.write(no_plasticity_input)
modes = '2 0 0 0 NPHMX, NMODMX, NTWMMX, NSYSMX\n'
else:
header = 'SLIP SYSTEMS FOR CUBIC CRYSTAL\n' \
'CUBIC icryst\n'
plastic_parameters.write(header)
crystal_axis = f' {self.TMaterials_2.item(0,23).text()} {self.TMaterials_2.item(0,24).text()} {self.TMaterials_2.item(0,25).text()} crystal axis (cdim(i))\n'
plastic_parameters.write(crystal_axis)
system_names = self.TMaterials_2.item(0,26).text()
num_systems = system_names.count(',') + 1
nmodes = f' {num_systems} nmodesx (total # of modes listed in the file)\n' \
f' {num_systems} nmodes (# of modes to be used in the calculation)\n'
plastic_parameters.write(nmodes)
modei = ' 1'
for i in range(num_systems-1):
modei = modei + f' {i+2}'
modei = modei + ' mode(i) (label of the modes to be used)\n'
plastic_parameters.write(modei)
slip_system_names = system_names.split(',')
nsmx_max = 0
for i in range(num_systems):
slip_system_name = slip_system_names[i].split('.', 1)[1].strip()
dict = slip_system_names[i].split('.', 1)[0].strip()
dvar = f'T{dict}'
slip_table = getattr(self, dvar)
nsmx = slip_table.rowCount()
if nsmx > nsmx_max:
nsmx_max = nsmx
slip_parameters = f' {slip_system_name} SLIP\n' \
f' {i+1} {nsmx} {self.TMaterials_2.item(0,27).text().split(",")[i]} {self.TMaterials_2.item(0,28).text().split(",")[i]} 0.0 0 modex,nsmx,nrsx,gamd0x,twshx,isectwx\n' \
f' {self.TMaterials_2.item(0,29).text().split(",")[i]} {self.TMaterials_2.item(0,30).text().split(",")[i]} {self.TMaterials_2.item(0,31).text().split(",")[i]} {self.TMaterials_2.item(0,32).text().split(",")[i]} {self.TMaterials_2.item(0,33).text().split(",")[i]} tau0xf,tau0xb,tau1x,thet0,thet1\n' \
f' {self.TMaterials_2.item(0,34).text().split(",")[i]}'
for ii in range(num_systems):
slip_parameters = slip_parameters + f' {self.TMaterials_2.item(0,35).text().split(",")[i]}'
slip_parameters = slip_parameters + ' hselfx,hlatex\n'
plastic_parameters.write(slip_parameters)
for j in range(nsmx):
slip_plane = slip_table.item(j,0).text().split(',')
slip_system = ' '
for k in range(len(slip_plane)):
slip_system = slip_system + f'{slip_plane[k]} '
slip_direction = slip_table.item(j,1).text().split(',')
for k in range(len(slip_direction)):
slip_system = slip_system + f' {slip_direction[k]}'
if j == 0:
slip_system = slip_system + ' SLIP (n-b)\n'
else:
slip_system = slip_system + '\n'
plastic_parameters.write(slip_system)
modes = f'1 1 1 {nsmx_max} NPHMX, NMODMX, NTWMMX, NSYSMX\n'
plastic_parameters.close()

# Elastic Input File
if 'Isotropic' in self.TMaterials_2.item(0,1).text() or 'Transversely Isotropic' in self.TMaterials_2.item(0,1).text() or 'Orthotropic' in self.TMaterials_2.item(0,1).text():
elastic_parameters = open(self.BULK_FORMING_ELASTIC_PARAMETERS,"w")
iso = '0\n'
elastic_parameters.write(iso)
stiffness = f' {self.TMaterials_2.item(0,2).text()} {self.TMaterials_2.item(0,3).text()} {self.TMaterials_2.item(0,4).text()} 0 0 0 Cu (MPa)\n' \
f' {self.TMaterials_2.item(0,3).text()} {self.TMaterials_2.item(0,8).text()} {self.TMaterials_2.item(0,9).text()} 0 0 0\n' \
f' {self.TMaterials_2.item(0,4).text()} {self.TMaterials_2.item(0,9).text()} {self.TMaterials_2.item(0,13).text()} 0 0 0\n' \
f' 0 0 0 {self.TMaterials_2.item(0,17).text()} 0 0\n' \
f' 0 0 0 0 {self.TMaterials_2.item(0,20).text()} 0\n' \
f' 0 0 0 0 0 {self.TMaterials_2.item(0,22).text()}'
elastic_parameters.write(stiffness)
elastic_parameters.close()
elif self.TMaterials_2.item(0,1).text() == 'Anisotropic':
elastic_parameters = open(self.BULK_FORMING_ELASTIC_PARAMETERS,"w")
iso = '0\n'
elastic_parameters.write(iso)
stiffness = f' {self.TMaterials_2.item(0,2).text()} {self.TMaterials_2.item(0,3).text()} {self.TMaterials_2.item(0,4).text()} {self.TMaterials_2.item(0,5).text()} {self.TMaterials_2.item(0,6).text()} {self.TMaterials_2.item(0,7).text()} Cu (MPa)\n' \
f' {self.TMaterials_2.item(0,3).text()} {self.TMaterials_2.item(0,8).text()} {self.TMaterials_2.item(0,9).text()} {self.TMaterials_2.item(0,10).text()} {self.TMaterials_2.item(0,11).text()} {self.TMaterials_2.item(0,12).text()}\n' \
f' {self.TMaterials_2.item(0,4).text()} {self.TMaterials_2.item(0,9).text()} {self.TMaterials_2.item(0,13).text()} {self.TMaterials_2.item(0,14).text()} {self.TMaterials_2.item(0,15).text()} {self.TMaterials_2.item(0,16).text()}\n' \
f' {self.TMaterials_2.item(0,5).text()} {self.TMaterials_2.item(0,10).text()} {self.TMaterials_2.item(0,14).text()} {self.TMaterials_2.item(0,17).text()} {self.TMaterials_2.item(0,18).text()} {self.TMaterials_2.item(0,19).text()}\n' \
f' {self.TMaterials_2.item(0,6).text()} {self.TMaterials_2.item(0,11).text()} {self.TMaterials_2.item(0,15).text()} {self.TMaterials_2.item(0,18).text()} {self.TMaterials_2.item(0,20).text()} {self.TMaterials_2.item(0,21).text()}\n' \
f' {self.TMaterials_2.item(0,7).text()} {self.TMaterials_2.item(0,12).text()} {self.TMaterials_2.item(0,16).text()} {self.TMaterials_2.item(0,19).text()} {self.TMaterials_2.item(0,21).text()} {self.TMaterials_2.item(0,22).text()}\n'
elastic_parameters.write(stiffness)
elastic_parameters.close()

# Bulk Forming input parameters file
bulk_forming_input = open(self.BULK_FORMING_INPUT,"w")
bulk_forming_input.write(modes)
Nx = int(self.TParts.item(0,7).text())
Ny = int(self.TParts.item(0,8).text())
Nz = int(self.TParts.item(0,9).text())
dimensions = f'{Nx} {Ny} {Nz} x-dim, y-dim, z-dim\n'
bulk_forming_input.write(dimensions)
nph = '1 number of phases (nph)\n'
bulk_forming_input.write(nph)
dx = float(self.TParts.item(0,4).text())/Nx
dy = float(self.TParts.item(0,5).text())/Ny
dz = float(self.TParts.item(0,6).text())/Nz
delt = f'{dx:.4f} {dy:.4f} {dz:.4f} RVE dimensions (delt)\n' + '* name and path of microstructure file (filetext)\n'
bulk_forming_input.write(delt)
partfile = self.TParts.item(0,10).text() + '\n'
bulk_forming_input.write(partfile)
phase1 = '*INFORMATION ABOUT PHASE #1\n' \
'0 igas(iph)\n' \
'* name and path of single crystal files (filecryspl, filecrysel) (dummy if igas(iph)=1)\n' \
f'{self.BULK_FORMING_PLASTIC_PARAMETERS}\n' \
f'{self.BULK_FORMING_ELASTIC_PARAMETERS}\n' \
'*INFORMATION ABOUT TEST CONDITIONS\n'
bulk_forming_input.write(phase1)
boundary_conditions_title = '* boundary conditions\n'
bulk_forming_input.write(boundary_conditions_title)
iudot11 = 0 if self.TVgrad.item(0,0) is None or self.TVgrad.item(0,0).text() == "" else 1
iudot12 = 0 if self.TVgrad.item(0,1) is None or self.TVgrad.item(0,1).text() == "" else 1
iudot13 = 0 if self.TVgrad.item(0,2) is None or self.TVgrad.item(0,2).text() == "" else 1
iudot21 = 0 if self.TVgrad.item(1,0) is None or self.TVgrad.item(1,0).text() == "" else 1
iudot22 = 0 if self.TVgrad.item(1,1) is None or self.TVgrad.item(1,1).text() == "" else 1
iudot23 = 0 if self.TVgrad.item(1,2) is None or self.TVgrad.item(1,2).text() == "" else 1
iudot31 = 0 if self.TVgrad.item(2,0) is None or self.TVgrad.item(2,0).text() == "" else 1
iudot32 = 0 if self.TVgrad.item(2,1) is None or self.TVgrad.item(2,1).text() == "" else 1
iudot33 = 0 if self.TVgrad.item(2,2) is None or self.TVgrad.item(2,2).text() == "" else 1
iudot = f' {iudot11} {iudot12} {iudot13} iudot | flag for vel.grad.\n' \
f' {iudot21} {iudot22} {iudot23} | (0:unknown-1:known)\n' \
f' {iudot31} {iudot32} {iudot33} |\n' \
f' |\n'
bulk_forming_input.write(iudot)
udot11 = 0. if self.TVgradi.item(0,0) is None or self.TVgradi.item(0,0).text() == "" else self.TVgradi.item(0,0).text()
udot12 = 0. if self.TVgradi.item(0,1) is None or self.TVgradi.item(0,1).text() == "" else self.TVgradi.item(0,1).text()
udot13 = 0. if self.TVgradi.item(0,2) is None or self.TVgradi.item(0,2).text() == "" else self.TVgradi.item(0,2).text()
udot21 = 0. if self.TVgradi.item(1,0) is None or self.TVgradi.item(1,0).text() == "" else self.TVgradi.item(1,0).text()
udot22 = 0. if self.TVgradi.item(1,1) is None or self.TVgradi.item(1,1).text() == "" else self.TVgradi.item(1,1).text()
udot23 = 0. if self.TVgradi.item(1,2) is None or self.TVgradi.item(1,2).text() == "" else self.TVgradi.item(1,2).text()
udot31 = 0. if self.TVgradi.item(2,0) is None or self.TVgradi.item(2,0).text() == "" else self.TVgradi.item(2,0).text()
udot32 = 0. if self.TVgradi.item(2,1) is None or self.TVgradi.item(2,1).text() == "" else self.TVgradi.item(2,1).text()
udot33 = 0. if self.TVgradi.item(2,2) is None or self.TVgradi.item(2,2).text() == "" else self.TVgradi.item(2,2).text()
udot = f' {udot11} {udot12} {udot13} udot | vel.grad\n' \
f' {udot21} {udot22} {udot23} |\n' \
f' {udot31} {udot32} {udot33} |\n' \
f' |\n'
bulk_forming_input.write(udot)
iscau11 = 0 if self.TCstress.item(0,0) is None or self.TCstress.item(0,0).text() == "" else 1
iscau12 = 0 if self.TCstress.item(0,1) is None or self.TCstress.item(0,1).text() == "" else 1
iscau13 = 0 if self.TCstress.item(0,2) is None or self.TCstress.item(0,2).text() == "" else 1
iscau22 = 0 if self.TCstress.item(1,1) is None or self.TCstress.item(1,1).text() == "" else 1
iscau23 = 0 if self.TCstress.item(1,2) is None or self.TCstress.item(1,2).text() == "" else 1
iscau33 = 0 if self.TCstress.item(2,2) is None or self.TCstress.item(2,2).text() == "" else 1
iscau = f' {iscau11} {iscau12} {iscau13} iscau | flag for Cauchy\n' \
f' {iscau22} {iscau23} |\n' \
f' {iscau33} |\n' \
f' |\n'
bulk_forming_input.write(iscau)
scauchy11 = 0. if self.TCstress.item(0,0) is None or self.TCstress.item(0,0).text() == "" else self.TCstress.item(0,0).text()
scauchy12 = 0. if self.TCstress.item(0,1) is None or self.TCstress.item(0,1).text() == "" else self.TCstress.item(0,1).text()
scauchy13 = 0. if self.TCstress.item(0,2) is None or self.TCstress.item(0,2).text() == "" else self.TCstress.item(0,2).text()
scauchy22 = 0. if self.TCstress.item(1,1) is None or self.TCstress.item(1,1).text() == "" else self.TCstress.item(1,1).text()
scauchy23 = 0. if self.TCstress.item(1,2) is None or self.TCstress.item(1,2).text() == "" else self.TCstress.item(1,2).text()
scauchy33 = 0. if self.TCstress.item(2,2) is None or self.TCstress.item(2,2).text() == "" else self.TCstress.item(2,2).text()
scauchy = f' {scauchy11} {scauchy12} {scauchy13} scauchy | Cauchy stress\n' \
f' {scauchy22} {scauchy23} |\n' \
f' {scauchy33} @\n'
bulk_forming_input.write(scauchy)
other = '* other\n' + \
f'{self.INBFdt.text()} eqincr (if ictrl>=0) or tdot (if ictrl=-1)\n' + \
'-1 ictrl (1-6: strain comp, 0: VM eq, -1: tdot)\n'
bulk_forming_input.write(other)
run_conditions = f'*INFORMATION ABOUT RUN CONDITIONS\n' + \
f'{self.INBFloadsteps.text()} nsteps\n' + \
f'{self.INBFerrortol.text()} err\n' + \
f'{self.INBFmaxiter.text()} itmax\n' + \
f'0 IRECOVER read grain states from STRESS.IN (1) or not (0)?\n' + \
f'0 ISAVE write grain states in STRESS.OUT (1) or not (0)?\n' + \
f'1 IUPDATE update tex & RVE dim (1) or not (0)?\n' + \
f'1 IUPHARD\n' + \
f'1 IWTEX\n' + \
f'1 {self.INBFoutputsteps.text()} IWFIELDS,IWSTEP\n' + \
f'0 ITHERMO (if ithermo=1, next line is filethermo)\n' + \
f'dummy\n'
bulk_forming_input.write(run_conditions)
bulk_forming_input.close()

Loading