Coverage for pySDC/projects/parallelSDC_reloaded/convergence.py: 100%
38 statements
« prev ^ index » next coverage.py v7.6.1, created at 2024-09-09 14:59 +0000
« prev ^ index » next coverage.py v7.6.1, created at 2024-09-09 14:59 +0000
1#!/usr/bin/env python3
2# -*- coding: utf-8 -*-
3"""
4Created on Tue Jan 9 14:44:41 2024
6Generate convergence plots on Dahlquist for SDC with given parameters
7"""
8import numpy as np
9from pySDC.projects.parallelSDC_reloaded.utils import getParamsRK, getParamsSDC, solutionSDC, plt
11SCRIPT = __file__.split('/')[-1].split('.')[0]
13# Script parameters
14lam = 1j
15tEnd = 2 * np.pi
16nStepsList = np.array([2, 5, 10, 20, 50, 100, 200, 500, 1000])
17dtVals = tEnd / nStepsList
20def getError(uNum, uRef):
21 if uNum is None: # pragma: no cover
22 return np.inf
23 return np.linalg.norm(uRef - uNum[:, 0], np.inf)
26# Collocation parameters
27nNodes = 4
28nodeType = "LEGENDRE"
29quadType = "RADAU-RIGHT"
30sweepType = "MIN-SR-NS"
32# Schemes parameters
33schemes = [("RK4", None), ("ESDIRK43", None), *[(sweepType, i) for i in [1, 2, 3, 4]][:1]]
35styles = [
36 dict(ls=":", c="gray"),
37 dict(ls="-.", c="gray"),
38 dict(ls="-", marker='o'),
39 dict(ls="-", marker='>'),
40 dict(ls="-", marker='s'),
41 dict(ls="-", marker='^'),
42 dict(ls="-", marker='*'),
43]
45# -----------------------------------------------------------------------------
46# Script execution
47# -----------------------------------------------------------------------------
48plt.figure()
49for (qDelta, nSweeps), style in zip(schemes, styles):
50 if nSweeps is None:
51 params = getParamsRK(qDelta)
52 label = None
53 else:
54 params = getParamsSDC(quadType, nNodes, qDelta, nSweeps, nodeType)
55 label = f"$K={nSweeps}$"
56 errors = []
58 for nSteps in nStepsList:
59 uNum, counters, parallel = solutionSDC(tEnd, nSteps, params, 'DAHLQUIST', lambdas=np.array([lam]))
61 tVals = np.linspace(0, tEnd, nSteps + 1)
62 uExact = np.exp(lam * tVals)
64 err = getError(uNum, uExact)
65 errors.append(err)
67 plt.loglog(dtVals, errors, **style, label=label)
68 if nSweeps is not None:
69 plt.loglog(dtVals, (0.1 * dtVals) ** nSweeps, '--', c='gray', lw=1.5)
71plt.title(sweepType)
72plt.legend()
73plt.xlabel(r"$\Delta{t}$")
74plt.ylabel(r"$L_\infty$ error")
75plt.grid(True)
76plt.tight_layout()