Study the Formation of a Shock Wave
Use Burgers' equation for viscous fluid flow to study the formation of a shock wave.
In[1]:=
data:image/s3,"s3://crabby-images/3c048/3c0484fdab0135c4ccaa62d03eda2ba380b67030" alt="Click for copyable input"
TraditionalForm[BurgersEquation = \!\(
\*SubscriptBox[\(\[PartialD]\), \({t}\)]\(u[x, t]\)\) + u[x, t] \!\(
\*SubscriptBox[\(\[PartialD]\), \({x}\)]\(u[x,
t]\)\) == \[Epsilon] \!\(
\*SubscriptBox[\(\[PartialD]\), \({x, 2}\)]\(u[x, t]\)\)]
Out[1]//TraditionalForm=
data:image/s3,"s3://crabby-images/f0159/f015966ed341baa594f511ff0b0686aef5a7c9f1" alt=""
Prescribe a piecewise initial condition.
In[2]:=
data:image/s3,"s3://crabby-images/63a7d/63a7de192f96a2ddd7adaf48a59549ad3f439201" alt="Click for copyable input"
InitialCondition = u[x, 0] == Piecewise[{{1, x < 0}}];
Solve the initial value problem.
In[3]:=
data:image/s3,"s3://crabby-images/aa19f/aa19f17027ab1a4d87de5b24a71ea387d6db82dc" alt="Click for copyable input"
dsol = DSolveValue[{BurgersEquation, InitialCondition},
u[x, t], {x, t}]
Out[3]=
data:image/s3,"s3://crabby-images/925d9/925d9ff1153de5db2fe2e276fb03d3b6802a633e" alt=""
The solution is smooth for any positive value of ϵ.
In[4]:=
data:image/s3,"s3://crabby-images/cfcec/cfcecbc6ed06e3bafbd8c478be61e9a8fd27fd99" alt="Click for copyable input"
Plot3D[dsol /. {\[Epsilon] -> 1/10}, {x, -2, 2}, {t, 0.001, 5}]
Out[4]=
data:image/s3,"s3://crabby-images/15424/1542484ad3ef9bbaf6defbcdac4c15e76cbb4de4" alt=""
The solution develops a shock discontinuity in the limit when ϵ approaches 0.
In[5]:=
data:image/s3,"s3://crabby-images/53811/538115d48ac3df950a9d01a1af425cf0da6ec943" alt="Click for copyable input"
Row[Table[Plot3D[dsol, {x, -2, 2}, {t, 0.001, 5},
Exclusions -> None, Ticks -> None],
{\[Epsilon], {1/10, 1/100, 1/1000}}]]
Out[5]=
data:image/s3,"s3://crabby-images/71496/7149604a29a47701b57cfaa3fc111047860ce2bd" alt=""