-
Notifications
You must be signed in to change notification settings - Fork 52
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into current_voxels
- Loading branch information
Showing
11 changed files
with
1,236 additions
and
329 deletions.
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
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,60 @@ | ||
#!/usr/bin/env python | ||
|
||
""" | ||
This script performs an optimization of the HTS tape winding angle | ||
with respect to binormal curvature and torsional strain cost functions as defined in | ||
Paz Soldan, "Non-planar coil winding angle optimization for compatibility with | ||
non-insulated high-temperature superconducting magnets", Journal of Plasma Physics | ||
86 (2020), doi:10.1017/S0022377820001208. | ||
The orientation of the tape is defined with respect to the Frenet-Serret Frame | ||
""" | ||
|
||
import numpy as np | ||
from scipy.optimize import minimize | ||
from simsopt.geo import CoilStrain, LPTorsionalStrainPenalty, LPBinormalCurvatureStrainPenalty | ||
from simsopt.geo import FrameRotation, FramedCurveFrenet, CurveXYZFourier | ||
from simsopt.configs import get_hsx_data | ||
from simsopt.util import in_github_actions | ||
|
||
MAXITER = 50 if in_github_actions else 400 | ||
|
||
curves, currents, ma = get_hsx_data(Nt_coils=10, ppp=10) | ||
curve = curves[1] | ||
scale_factor = 0.1 | ||
curve_scaled = CurveXYZFourier(curve.quadpoints, curve.order) | ||
curve_scaled.x = curve.x * scale_factor # scale coil to magnify the strains | ||
rot_order = 10 # order of the Fourier expression for the rotation of the filament pack | ||
width = 1e-3 # tape width | ||
|
||
curve_scaled.fix_all() # fix curve DOFs -> only optimize winding angle | ||
rotation = FrameRotation(curve_scaled.quadpoints, rot_order) | ||
|
||
framedcurve = FramedCurveFrenet(curve_scaled, rotation) | ||
|
||
tor_threshold = 0.02 # Threshold for strain parameters | ||
cur_threshold = 0.02 | ||
|
||
Jtor = LPTorsionalStrainPenalty(framedcurve, p=2, threshold=tor_threshold) | ||
Jbin = LPBinormalCurvatureStrainPenalty( | ||
framedcurve, p=2, threshold=cur_threshold) | ||
|
||
strain = CoilStrain(framedcurve, width) | ||
JF = Jtor + Jbin | ||
|
||
|
||
def fun(dofs): | ||
JF.x = dofs | ||
J = JF.J() | ||
grad = JF.dJ() | ||
outstr = f"Max torsional strain={np.max(strain.torsional_strain()):.1e}, Max curvature strain={np.max(strain.binormal_curvature_strain()):.1e}" | ||
print(outstr) | ||
return J, grad | ||
|
||
|
||
f = fun | ||
dofs = JF.x | ||
|
||
res = minimize(fun, dofs, jac=True, method='L-BFGS-B', | ||
options={'maxiter': MAXITER, 'maxcor': 10, 'gtol': 1e-20, 'ftol': 1e-20}, tol=1e-20) |
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
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
Oops, something went wrong.