I am trying to have two panels, the left showing a graphic and two locators, the right one a zoomed-in version in the area defined by the locators.
I’ve tried
ClearAll[mndpt];
mndpt = Compile[{{c, _Complex}, {maxiter, _Integer}},
Module[{z, iters},
iters = 0.;
z = c;
While[(iters < maxiter) && (Abs@z < 2),
iters++;
z = z^2 + c];
Sqrt[iters/maxiter]],
{{z, _Complex}},
CompilationTarget \[Rule] "C",
RuntimeOptions \[Rule] "Speed"];
and do
Manipulate[
Grid[
{{DensityPlot[mndpt[x + y*I, 200],
{x, -2, 1}, {y, -1.5, 1.5},
PlotRange \[Rule] {0, 1}, PlotPoints \[Rule] 80,
ColorFunction \[Rule] "Rainbow"],
DensityPlot[mndpt[x + y*I, 200],
Dynamic@{x, p1[[1]], p2[[1]]}, Dynamic@{y, p1[[2]], p2[[2]]},
PlotRange \[Rule] {0, 1}, PlotPoints \[Rule] 80,
ColorFunction \[Rule] "Rainbow"]}}],
{{p1, {-1, -1}}, Locator}, {{p2, {0, 1}}, Locator}]
The right panel does not then work:

My question is, why is this so? As you can see, it complains that “DensityPlot::pllim: Range specification {x,-1,0} is not of the form {x, xmin, xmax}. ” which I find puzzling. In fact I am generally puzzled. What is going on? Some sort of scoping issue? Evaluation issue? And how can I get it to work? This is probably simple, but I never really understood this frontend stuff.
EDIT: It turns out that this question was due to a (hopefully momentary) sharp increase in stupidity on my part. As pointed out by Simon in a comment, removing the two Dynamics
(which I had added in a blind effort to make this work) makes everything work fine. That is,
Manipulate[
Grid[
{{DensityPlot[mndpt[x + y*I, 200],
{x, -2, 1}, {y, -1.5, 1.5},
PlotRange \[Rule] {0, 1}, PlotPoints \[Rule] 80,
ColorFunction \[Rule] "Rainbow"],
DensityPlot[mndpt[x + y*I, 200],
{x, p1[[1]], p2[[1]]},{y, p1[[2]], p2[[2]]},
PlotRange \[Rule] {0, 1}, PlotPoints \[Rule] 80,
ColorFunction \[Rule] "Rainbow"]}}],
{{p1, {-1, -1}}, Locator}, {{p2, {0, 1}}, Locator}]
does the right thing:

So, who knows why else I did the first few times so that it didn’t work.
On the other hand, the message in the original case, namely, “DensityPlot::pllim: Range specification {x,-1,0} is not of the form {x, xmin, xmax}. ” was more puzzling. I think it’s been explained by Leonid, also in a comment (in brief, try ClearAttributes[Dynamic, ReadProtected] then ??Dynamic and you can see that there is a definition Dynamic/:MakeBoxes[BoxForm`x$_Dynamic,StandardForm]:= etc). As my understanding of frontend programming is negligible I won’t try to explain it here, so if anybody does post an answer explaining that, it would be appreciated.
As discussed in the comments to the question, the code works fine if the
Dynamics are removed from the ranges in the secondDensityPlot. TheDynamics are not normally needed in the body of aManipulateas it is automatically wrapped in a dynamic construct. Although, for a more fine grained control of which parts of an expression update, it can be useful to useDynamicinside of aManipulate.The reason an error was created was because the range of a plot should be of the form
{x, xmin, xmax}withxaSymbolandxminandxmaxnumeric. WrappingDynamicaround the list changes the head and breaks the plot.The reason that the error was not obvious to spot is because the error message was a little confusing:
Which, on the surface looks crazy, but makes sense once you realise (as pointed out by Leonid) that
Dynamicis a wrapper that has aMakeBoxesdefinition that makes it invisible when outputted to the notebook. To see this, look atand
ControlToBoxesin turn, creates aDynamicBoxobject. This can also be seen by enteringDynamic[x]and using the cell menu or shortcut to Show Expression of the produced output cell – you can also look at the underlying expression of the error message and see theDynamicBoxconstruction there. It’s also possible toUnprotectand remove theMakeBoxesdefinition ofDynamic, but that breaks most of the dynamic functionality in Mathematica…Finally, here’s my version of the code: