Coverage for pySDC / projects / parallelSDC_reloaded / scripts / fig05_allenCahn.py: 100%
75 statements
« prev ^ index » next coverage.py v7.13.5, created at 2026-03-23 17:16 +0000
« prev ^ index » next coverage.py v7.13.5, created at 2026-03-23 17:16 +0000
1#!/usr/bin/env python3
2# -*- coding: utf-8 -*-
3"""
4Created on Thu Jan 11 11:14:01 2024
6Figures with experiments on the Allen-Cahn problem
7"""
9import os
10import numpy as np
12from pySDC.projects.parallelSDC_reloaded.utils import solutionExact, getParamsSDC, solutionSDC, getParamsRK, plt
13from pySDC.helpers.testing import DataChecker
15data = DataChecker(__file__)
17PATH = '/' + os.path.join(*__file__.split('/')[:-1])
18SCRIPT = __file__.split('/')[-1].split('.')[0]
20symList = ['o', '^', 's', '>', '*', '<', 'p', '>'] * 10
22# SDC parameters
23nNodes = 4
24quadType = 'RADAU-RIGHT'
25nodeType = 'LEGENDRE'
26parEfficiency = 0.8 # 1/nNodes
27nSweeps = 4
29# Problem parameters
30pName = "ALLEN-CAHN"
31tEnd = 50
32pParams = {
33 "periodic": False,
34 "nvars": 2**11 - 1,
35 "epsilon": 0.04,
36}
38# -----------------------------------------------------------------------------
39# Trajectories (reference solution)
40# -----------------------------------------------------------------------------
41uExact = solutionExact(tEnd, 1, pName, **pParams)
42x = np.linspace(-0.5, 0.5, 2**11 + 1)[1:-1]
44figName = f"{SCRIPT}_solution"
45plt.figure(figName)
46plt.plot(x, uExact[0, :], '-', label="$u(0)$")
47plt.plot(x, uExact[-1, :], '--', label="$u(T)$")
49plt.legend()
50plt.xlabel("$x$")
51plt.ylabel("Solution")
52plt.gcf().set_size_inches(12, 3)
53plt.tight_layout()
54plt.savefig(f"{PATH}/{figName}.pdf")
56# -----------------------------------------------------------------------------
57# %% Convergence and error VS cost plots
58# -----------------------------------------------------------------------------
59nStepsList = np.array([1, 2, 5, 10, 20, 50, 100, 200, 500])
60dtVals = tEnd / nStepsList
63def getError(uNum, uRef):
64 if uNum is None:
65 return np.inf
66 return np.linalg.norm(uRef[-1, :] - uNum[-1, :], ord=2)
69def getCost(counters):
70 nNewton, nRHS, tComp = counters
71 return 2 * nNewton + nRHS
74minPrec = ["MIN-SR-NS", "MIN-SR-S", "MIN-SR-FLEX"]
76symList = ['^', '>', '<', 'o', 's', '*', 'p']
77config = [
78 (*minPrec, "VDHS", "ESDIRK43", "LU"),
79]
82i = 0
83for qDeltaList in config:
84 figNameConv = f"{SCRIPT}_conv_{i}"
85 figNameCost = f"{SCRIPT}_cost_{i}"
86 i += 1
88 for qDelta, sym in zip(qDeltaList, symList, strict=False):
89 try:
90 params = getParamsRK(qDelta)
91 except KeyError:
92 params = getParamsSDC(
93 quadType=quadType, numNodes=nNodes, nodeType=nodeType, qDeltaI=qDelta, nSweeps=nSweeps
94 )
96 errors = []
97 costs = []
99 for nSteps in nStepsList:
100 uRef = solutionExact(tEnd, nSteps, pName, **pParams)
102 uSDC, counters, parallel = solutionSDC(tEnd, nSteps, params, pName, **pParams)
104 err = getError(uSDC, uRef)
105 errors.append(err)
107 cost = getCost(counters)
108 if parallel:
109 cost /= nNodes * parEfficiency
110 costs.append(cost)
112 ls = '-' if qDelta.startswith("MIN-SR-") else "--"
114 plt.figure(figNameConv)
115 plt.loglog(dtVals, errors, sym + ls, label=qDelta)
116 data.storeAndCheck(f"{figNameConv}_{qDelta}", errors, atol=1e-4, rtol=1e-4)
118 plt.figure(figNameCost)
119 plt.loglog(costs, errors, sym + ls, label=qDelta)
121 for figName in [figNameConv, figNameCost]:
122 plt.figure(figName)
123 plt.gca().set(
124 xlabel="Cost" if "cost" in figName else r"$\Delta {t}$",
125 ylabel=r"$L_2$ error at $T$",
126 )
127 plt.legend()
128 plt.grid(True)
129 plt.tight_layout()
130 plt.savefig(f"{PATH}/{figName}.pdf")
132data.writeToJSON()