Source code for pycalphad.core.constraints
from pycalphad.core.constants import INTERNAL_CONSTRAINT_SCALING
from pycalphad.codegen.sympydiff_utils import build_constraint_functions
from collections import namedtuple
ConstraintTuple = namedtuple('ConstraintTuple', ['internal_cons_func', 'internal_cons_jac', 'internal_cons_hess',
'num_internal_cons'])
[docs]
def build_constraints(mod, variables, parameters=None):
internal_constraints = mod.get_internal_constraints()
internal_constraints = [INTERNAL_CONSTRAINT_SCALING*x for x in internal_constraints]
cf_output = build_constraint_functions(variables, internal_constraints,
parameters=parameters)
internal_cons_func = cf_output.cons_func
internal_cons_jac = cf_output.cons_jac
internal_cons_hess = cf_output.cons_hess
return ConstraintTuple(internal_cons_func=internal_cons_func, internal_cons_jac=internal_cons_jac,
internal_cons_hess=internal_cons_hess,
num_internal_cons=len(internal_constraints))
[docs]
def build_phase_local_constraints(mod, variables, phase_local_conditions, parameters=None):
import pycalphad.variables as v
phase_local_constraints = []
for key, value in phase_local_conditions.items():
if isinstance(key, v.MoleFraction):
cons = mod.moles(key.species, per_formula_unit=True) - \
value * sum(mod.moles(v.Species(el), per_formula_unit=True) for el in mod.nonvacant_elements)
elif isinstance(key, v.SiteFraction):
cons = key - value
else:
raise ValueError(f'Unsupported phase-local condition: {key}')
phase_local_constraints.append(cons.expand())
cf_output = build_constraint_functions(variables, phase_local_constraints,
parameters=parameters)
internal_cons_func = cf_output.cons_func
internal_cons_jac = cf_output.cons_jac
internal_cons_hess = cf_output.cons_hess
return ConstraintTuple(internal_cons_func=internal_cons_func, internal_cons_jac=internal_cons_jac,
internal_cons_hess=internal_cons_hess,
num_internal_cons=len(phase_local_constraints))