wiki:u/erica/MusclHancock

Introduction

The Muscl-Hancock scheme is a 2nd order numerical method. The higher the order of accuracy, the more convergent is the scheme. For instance, here is a plot of the Godunov 1st order upwind scheme (aka CIR scheme, 1st order monotone, what I have been using), the Lax Friedrichs scheme (1st order monotone), Lax Wendroff scheme (2nd order, non-monotone), and Warming-Beam (2nd order, non-monotone).

As you can see, the 1st order monotone schemes are more 'diffusive' than the higher order schemes, i.e. they clip extreme values of the solution. By the 1250 time steps, this effect is highly exaggerated:

On the other hand, the higher order schemes are 'dispersive'. That is, they suffer from slight sign errors in the position of the wave, with the numerical solution either lagging behind or ahead of the true solution.

The above plots show that 2nd order schemes largely perform better than 1st order schemes in regions of 'smooth flow'. However, it is well known that these same higher order accurate schemes can produce spurious oscillations near large gradients. This is due to the higher order schemes no longer being monotone (i.e. having strictly non-negative coefficients in their conservation update formula). Here is a plot showing the same 4 schemes listed above, but for a step function initial condition:

Note the ugly, spurious oscillations near the large gradients of the step function. Unfortunately, all monotone schemes (those that do not contain artificial oscillations) are 1st order at best. Thus, the challenge is to reduce these oscillations in regions of discontinuous flow while maximizing accuracy in regions of smooth flow. One such class of schemes are known as 'Total Variation Diminishing' (TVD). These schemes implicitly add artificial viscosity, resulting in smoother flows near large gradients. Such a scheme is the Muscl-Hancock scheme.

The Muscl Hancock (MH) Scheme

The goal of this method, like others we have looked at, is to solve the system of equations known as the 1D Euler equations,

where u is the vector of conserved variables (u=u(x,t)), and f is the flux function. Adhering to the IVBP known as the Riemann Problem (i.e. constant left and right data states separated by an initial discontinuity), we solve this system of equations using the fully discrete, explicit, conservative formula:

for each element of u, where f is the numerical flux. For the 1st order Godunov scheme studied previously, f was taken to simply be the physical flux of 2 adjacent cells (this is the so called 'Godunov numerical flux'), evaluated using the solution of the Local Riemann Problem (LRP) at the intercell boundary. We have seen various approximation methods to this Godonov scheme, some which estimate the solution of the Riemann problem itself along these intercell boundaries, and others that instead approximate the numerical flux at these boundaries. Next, we will see how the MH scheme produces a 2nd-order accurate solution to the problem. The MH scheme proceeds as follows, being broken down into 3 distinct steps.

  1. 'Data reconstruction' - this is the first step of the MH scheme, and is responsible for providing higher order accuracy by fitting a piece-wise linear function to the initial piece-wise constant data. Note that this step maintains conservation. Such a piece-wise linear function is of the form:

where

is called a 'slope' for

,

that is, for the elements of in cell i on the nth time level. Using a linear function produces 2 extreme values of each cell, one on the left and on the right (ul and ur). These values are crucial in the MH scheme and their role will be presented shortly. Their values are given by

and

A schematic of the situation is as follows:

Using these end values, one has the new Riemann problem:

where 0 is the local origin, i.e. any given intercell boundary. Given that the expressions for ul and ur involve the slope , we define

where w is a free parameter in the real interval [-1,1] and

  1. Boundary evolution - this step 'evolves' the left and right values of u (ul and ur). It is actually these values of ul and ur that are used in the Riemann problem outlined in step 1. The formulas used to evolve each boundary extrapolated value are:

A schematic of the situation is depicted here for reference:

  1. Solve the new Riemann problem

using the evolved extrapolated boundary values. The solution of this problem is then used in the Godunov flux, which is used in updating cell i. Recall the Godunov flux is simply,

i.e. the numerical flux at the intercell boundary equals the physical flux evaluated at the similarity solution of the LRP (local Riemann Problem) at that boundary.

At this point, we are left with a higher order accurate code, but not one that is free of spurious oscillations near large gradients. To circumvent this, we need to add a TVD measure. There are some different ways of doing this, i.e. limited slopes, flux-limiters, and slope limiters. Using one of these methods, you would replace the slope function in steps 1 and 2 with a TVD version of the slope. This leads to a scheme that is both higher order accurate as well as minimizes spurious oscillations.

To summarize, the MH scheme provides a means to solve for the numerical flux of the conservative update formula for cell i (*). This flux is just the regular Godunov flux, but now evaluated using the solution of the LRP consisting of left and right states that fit a piece-wise linear function. This linear function is chosen to both a) increase the order of accuracy, and b) satisfy TVD conditions. In the end we are left with a numerical solution that is both less dispersive in regions of smooth flow and less oscillatory near sharp gradients.

Results

As you can see here, the MH scheme + Superbee slope limiter + Roe solver produce highly non-diffusive results. However, there still are some small scale spurious oscillations near the boundary of the square wave.

,

,

,

Last modified 11 years ago Last modified on 07/10/13 13:55:57

Attachments (11)

Download all attachments as: .zip

Note: See TracWiki for help on using the wiki.