MathGroup Archive 2008

[Date Index] [Thread Index] [Author Index]

Search the Archive

Re: The show command freezes

  • To: mathgroup at smc.vnet.net
  • Subject: [mg90291] Re: The show command freezes
  • From: Aaron Fude <aaronfude at gmail.com>
  • Date: Fri, 4 Jul 2008 04:00:50 -0400 (EDT)
  • References: <g4d2sh$ep1$1@smc.vnet.net>

Fair enough. Here's the code!

F = 1000;
K1 = 2;  K2 = 1; g = 0.01; H1 = 14*F; H2 = 6*F; H = H1 + H2;
\[CapitalDelta]1[c_, k_] := c^2/K1^2 - 1;
\[CapitalGamma]1[c_, k_] := g/(k*K1^2);
U1[c_, k_] :=
  Power[\[CapitalGamma]1[c, k], 2] - 4*\[CapitalDelta]1[c, k];
Q1[c_, k_] := Sqrt[U1[c, k]];
A1[c_, k_] := 1/2 k*Q1[c, k]*H1;
\[CapitalPhi]1[c_, k_] := E^(-(1/2) k \[CapitalGamma]1[c, k] H1)/(
  2 I c Cosh[A1[c, k]]);
\[CapitalDelta]2[c_, k_] := c^2/K2^2 - 1;
\[CapitalGamma]2[c_, k_] := g/(k*K2^2);
U2[c_, k_] :=
  Power[\[CapitalGamma]2[c, k], 2] - 4*\[CapitalDelta]2[c, k];
Q2[c_, k_] := Sqrt[U2[c, k]];
A2[c_, k_] := 1/2 k*Q2[c, k]*H2;
\[CapitalPhi]2[c_, k_] := E^(1/2 k \[CapitalGamma]2[c, k] H2)/(
  2 I c Cosh[A2[c, k]]);
M[c_, k_] := (\[NoBreak]{
    {0, -2 \[CapitalDelta]1[c, k] Tanh[
       A1[c, k]], -2  \[CapitalDelta]2[c, k] Tanh[A2[c, k]]},
    {g, 0,  c k (Q2[c, k] + \[CapitalGamma]2[c, k] Tanh[A2[c, k]])},
    {g,  c k (Q1[c, k] - \[CapitalGamma]1[c, k] Tanh[A1[c, k]]), 0}
   }\[NoBreak]);
\[NoBreak]ns[c_, k_, tol_] := NullSpace[M[c, k], Tolerance -> tol]
(*fh[c_,k_]:=Det[M[c, k]]*)
fh[c_, k_] := \[CapitalDelta]1[c, k]*
    Tanh[A1[c,
      k]]*(Q2[c, k] + \[CapitalGamma]2[c, k]*
       Tanh[A2[c, k]]) + \[CapitalDelta]2[c, k]*
    Tanh[A2[c,
      k]]*(Q1[c, k] - \[CapitalGamma]1[c, k]*Tanh[A1[c, k]]);
ff[c_, k_] :=
  Piecewise[{{fh[c, k], ( U1[c, k] >= 0) && (U2[c, k] >= 0)}}, None];


FirstRoot[k_, p_] :=
  c /. FindRoot[(ff[c, m] /. m -> k) == 0, {c, 1.2},
    WorkingPrecision -> p + 5, PrecisionGoal -> p];

Needs["VectorFieldPlots`"]
k = 0.001;
c = FirstRoot[k, 40];

NS = ns[c, k, 10^-12];

ZRange = {0, H};

TicksYes = True;
L = 2*H;

vf1[x_, z_] := {\[CapitalGamma]1[c, k] + Q1[c, k], -2
      I \[CapitalDelta]1[c, k]}*E^(
    1/2 k (\[CapitalGamma]1[c, k] - Q1[c, k])
     z) - {\[CapitalGamma]1[c, k] - Q1[c, k], -2
      I \[CapitalDelta]1[c, k]}*E^(
    1/2 k (\[CapitalGamma]1[c, k] + Q1[c, k]) z);
vf2[x_, z_] := {\[CapitalGamma]2[c, k] + Q2[c, k], -2
      I \[CapitalDelta]2[c, k]}*E^(
    1/2 k (\[CapitalGamma]2[c, k] - Q2[c, k]) (z -
       H)) - {\[CapitalGamma]2[c, k] - Q2[c, k], -2
      I \[CapitalDelta]2[c, k]}*E^(
    1/2 k (\[CapitalGamma]2[c, k] + Q2[c, k]) (z - H));
vf[x_, z_] := Re[Piecewise[{
      {\[CapitalPhi]1[c, k] NS[[1]][[2]]*vf1[x, z], z < H1},
      {\[CapitalPhi]2[c, k] NS[[1]][[3]]*vf2[x, z], z > H1}}]*E^(
    I k (x - 2*c) )];
profile =
  ParametricPlot[{Abs[Norm[vf[0, z]]], z}, {z, 0, H},
   AxesOrigin -> {0, 0}, AspectRatio -> 1/1.5,
   Ticks -> {TicksYes, Automatic}, PlotStyle -> {Thick, Black},
   PlotRange -> {Full, ZRange},
   AxesLabel -> {"|v|", "z"}, PlotPoints -> 1000];

S0 = Graphics[{Dashed, Line[{{0, H1}, {1, H1}}]}];

Show[profile]
(*Show[profile, S0]*)   (* This line makes it freeze *)


  • Prev by Date: Re: ShowLegend font size
  • Next by Date: Re: lie symmetry package
  • Previous by thread: Re: The show command freezes
  • Next by thread: Re: The show command freezes