-
-
Notifications
You must be signed in to change notification settings - Fork 76
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add a sine wave tool to the graphtool. #1157
base: develop
Are you sure you want to change the base?
Conversation
2d8005b
to
13e3cb3
Compare
This will be a nice addition to the graph tool. In testing with the sample problem, I found some issues. Some feel like some sort of jxsgraph quirk. Something strange happens with the sample problem when you try to use one of the points on the left or right edge of the grid. You can move the mouse to select a point there, and the coordinate hints will indicate you are there at the edge. For example, at (8π, something). But it won't be showing a highlighted dot there. It will show a highlighted dot at (15/2 π, something instead). If I plot the first point somewhere, as I move the mouse around, the coordinate hints show where my mouse actually is, instead of showing the coordinates of the second (or third) point I am trying to pin down. Can this be made to show the coordinates of the restricted second dot you are trying to select? (And then for the third dot too, which is restricted vertically?) If I select the first dot at say (0,0), and then move the mouse to (0,0), a second dot remains visible at (1/2 π,0). But clicking, nothing happens. It is maybe confusing to see that dot at (1/2 π,0) and think you are at a place where you can hammer in the second point, but it won't let you. Perhaps related to things already mentioned. If I select the first dot at (15/2 π, 0), then move the mouse to (8π, 0), the sine wave that I see has a long period of 12π instead of the period π/2 I would expect. Then when I click to hammer that in, it switches to a wave with period π/2. |
This is something that I noticed recently as well. This is not how it used to work, and I think that something has changed with JSXGraph that is causing this. It used to be the case that you could place points on the edge, and it would all work intuitively. I messed with it a little bit to see if I could fix it, but ended up putting that off for now. Note that this happens with all of the tools and not just the new sine wave tool, and seems to not happen with certain board dimensions. For instance if the
I missed this. It should show the coordinates of the highlight point, but for some reason that isn't working right. I will look into it. This is actually something I have fought with quite a bit over the years. JSXGraph keeps changing something that messes with this.
I will see if there is anything that can be done about this. This works the same way that the other tools do, in that it doesn't allow the second point to be placed where the first is, and it is tricky to deal with when the mouse cursor is out of place. This seems to be made worse by the previous issue you mentioned and that fact that the coordinates shown are incorrect. They shouldn't show (0,0) ever while graphing the second point if that is where the first point is.
This seems to really be something to do with the first issue you mentioned. If that issue is fixed, then this one will most likely be resolved also. |
Could some of the jsxgraph edge issues be avoided if the plot always
extended by some epsilon past the declared bounds?
…On Wed, Dec 11, 2024, 6:12 PM Glenn Rice ***@***.***> wrote:
Something strange happens with the sample problem when you try to use one
of the points on the left or right edge of the grid. You can move the mouse
to select a point there, and the coordinate hints will indicate you are
there at the edge. For example, at (8π, something). But it won't be showing
a highlighted dot there. It will show a highlighted dot at (15/2 π,
something instead).
This is something that I noticed recently as well. This is not how it used
to work, and I think that something has changed with JSXGraph that is
causing this. It used to be the case that you could place points on the
edge, and it would all work intuitively. I messed with it a little bit to
see if I could fix it, but ended up putting that off for now. Note that
this happens with all of the tools and not just the new sine wave tool, and
seems to not happen with certain board dimensions. For instance if the
bBox is set to [-10, 10, 10, -10] with the defaults for all of the other
options, then it works fine.
If I plot the first point somewhere, as I move the mouse around, the
coordinate hints show where my mouse actually is, instead of showing the
coordinates of the second (or third) point I am trying to pin down. Can
this be made to show the coordinates of the restricted second dot you are
trying to select? (And then for the third dot too, which is restricted
vertically?)
I missed this. It should show the coordinates of the highlight point, but
for some reason that isn't working right. I will look into it. This is
actually something I have fought with quite a bit over the years. JSXGraph
keeps changing something that messes with this.
If I select the first dot at say (0,0), and then move the mouse to (0,0),
a second dot remains visible at (1/2 π,0). But clicking, nothing happens.
It is maybe confusing to see that dot at (1/2 π,0) and think you are at a
place where you can hammer in the second point, but it won't let you.
I will see if there is anything that can be done about this. This works
the same way that the other tools do, in that it doesn't allow the second
point to be placed where the first is, and it is tricky to deal with when
the mouse cursor is out of place. This seems to be made worse by the
previous issue you mentioned and that fact that the coordinates shown are
incorrect. They shouldn't show (0,0) ever while graphing the second point
if that is where the first point is.
Perhaps related to things already mentioned. If I select the first dot at
(15/2 π, 0), then move the mouse to (8π, 0), the sine wave that I see has a
long period of 12π instead of the period π/2 I would expect. Then when I
click to hammer that in, it switches to a wave with period π/2.
This seems to really be something to do with the first issue you
mentioned. If that issue is fixed, then this one will most likely be
resolved also.
—
Reply to this email directly, view it on GitHub
<https://urldefense.com/v3/__https://github.com/openwebwork/pg/pull/1157*issuecomment-2537598423__;Iw!!Ka_JY85zDv0FFw!j9e_7JItxDuK5T3Oe6oTF4gA5H65sIjsSN1HLBIBX7GYPVcBskDwzXRXOwnRKI9gcR5sG59d2vOHXP7OSM6nlvO_Izw$>,
or unsubscribe
<https://urldefense.com/v3/__https://github.com/notifications/unsubscribe-auth/ABEDOADUSI6C5GCOHXXDGV32FDWG5AVCNFSM6AAAAABTFQOLLGVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDKMZXGU4TQNBSGM__;!!Ka_JY85zDv0FFw!j9e_7JItxDuK5T3Oe6oTF4gA5H65sIjsSN1HLBIBX7GYPVcBskDwzXRXOwnRKI9gcR5sG59d2vOHXP7OSM6nGTfoRD4$>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
That isn't really something that can be done. |
Do you mean for a technical reason or something else? To be clear I don't
mean some fixed epsilon. I mean something like 0.1 times whatever the x- or
y- increment is.
…On Wed, Dec 11, 2024, 6:32 PM Glenn Rice ***@***.***> wrote:
That isn't really something that can be done.
—
Reply to this email directly, view it on GitHub
<https://urldefense.com/v3/__https://github.com/openwebwork/pg/pull/1157*issuecomment-2537658344__;Iw!!Ka_JY85zDv0FFw!hEvMqoQCozPenHt51wAp4NmvLk2duxyPyPqPu3iS9SIoPJHoD-547_PDz2d4yHj2YmaA0rYok9-yiuhrRhW_O-XyM6M$>,
or unsubscribe
<https://urldefense.com/v3/__https://github.com/notifications/unsubscribe-auth/ABEDOAE4O5LLLTZOACNNNDT2FDYUJAVCNFSM6AAAAABTFQOLLGVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDKMZXGY2TQMZUGQ__;!!Ka_JY85zDv0FFw!hEvMqoQCozPenHt51wAp4NmvLk2duxyPyPqPu3iS9SIoPJHoD-547_PDz2d4yHj2YmaA0rYok9-yiuhrRhW_eTgVQEI$>
.
You are receiving this because you commented.Message ID:
***@***.***>
|
I mean that it isn't something that JSXGraph supports. |
I mean, you can't just change the bounding box. That would mess things up visually, and many other things in the code as well. |
The second and third issues you listed are now fixed. The coordinate hints show the coordinates of the point being graphed. That was easy. I just forgot to return The other I implemented a better way than just refusing to plot a point when a click occurs when the coordinates are in an invalid location. It just plots the point where it is shown in that case instead. This needs to be done for all of the tools though, and not just the new sine wave tool. |
bb35b3e
to
8dfd032
Compare
So the issue seems to be a precision issue with the bounding box, snap size, and scaleX settings in the problem. If you instead set |
Although that doesn't explain the issue with a bounding box of |
Well, at some point before. Not sure when it starting not working. |
There is a line in
I am suggesting replace that line with:
and add the subroutine:
The author's bBox is still in |
Actually, your idea about adjusting the bounding box may work. If you add As I am typing this I see your last comment. It isn't a good idea to do this in the Perl portion of the code. It should be done in the JavaScript, and not use something so large as 0.1. |
This is a quick fix for now. I will look into it more. I am still not satisfied with enlarging the bounding box in this way. It could have other bad consequences. |
Do you have MathJax accessibility activated by chance? I had the same issue when I had that activated. The problem went away when I disabled MathJax accessibility. I don't know how to fix that. |
By the way, MathJax seems to have a bug with the accessibility settings. Once you activate them, you can not deactivate them. When you click on the checked "Activate" item in the MathJax menu, there are console log errors and it is not unchecked. The only way I have found to deactivate them is to go into the developer tools and delete the key that MathJax sets in local storage for this. |
Yes, that is it. If I turn off MathJax accessibility and reload the problem, the labeling is not off. Did you only see this with the new feature using multiples of pi as axis labels? In other words, is there a way to see this issue on develop right now? I could post an issue and ping Davide if he has insight about it. |
It is only an issue with using MathJax for the axis labels. It won't happen with the develop branch since it doesn't use MathJax for the axis labels. |
Note the issue with MathJax and its menu and not being able to disable accessibility is not related to JSXGraph or the graphtool at all though. |
OK, I had some trouble turning it off like you say. But I eventually got it off, and I didn't have to resort to going into the console. I can't repeat what I did though... |
The menu issue seems to be specific to Firefox. I just tried it in Chrome and didn't have the issue. |
I'm not having the same trouble turning off accessibility in a regular problem. Only (for now) in the problem editor. Could it be something about that endpoint or the iframe? |
Although in Chrome when I activate accessibility the rendered MathJax element that I clicked on to open the menu disappears. I am doing this testing in a problem in a set. Not sure if things are different in an iframe on the problem editor page. |
OK, well there is a separate mystery to pursue. I'll leave it out of this thread, sorry for the clutter. |
For the label positioning, if it is an issue, then we can switch back and not use MathJax for the labes. Then the unicode pi symbol would have to be used instead, and you have to add that either by using |
The unicode pi doesn't look as nice as the MathJax pi though. |
I think we should leave it as you made it, and separately pursue what the issue is with MathJax, perhaps with help from Davide. |
Okay. Good. I remembered the other issue with not using MathJax. Then fractions would be displayed as |
It's more than just π. Now you will be able to make an axis with, for example |
True. MathJax with the |
I updated the existing graph tools with the changes made for the sine wave tool. So now all of the tools switch to using the highlight point coordinates instead of refusing to plot a point. This is a massive improvement for the quadratic and cubic plotting tools. The issue you saw with the click not doing anything is really easy to make happen with those tools. With the quadratic tool if you plot three points on three consecutive vertical lines, then while graphing the fourth point anytime that you are in between the vertical lines of the previously graphed points you could click all you wanted to and nothing would happen. I have known about this issue for a while, and should have though of this solution sooner. Also, don't compare floating point numbers with |
15a7446
to
d9d2de8
Compare
I fixed the issue with the label positions being incorrect when MathJax accessibility is enabled. The key was to update the JXSGraph board after MathJax typesetting is completed. |
0130afa
to
88d2ff9
Compare
The tool can be added by setting `availableTools => [ 'SineWaveTool' ]` in the `->with` call when creating a `GraphTool` object. Of course other tools can be added in the list as well. The tool works by plotting three points. The first point determines the phase shift (or x translation) and y translation. The second point determines the amplitude. Note that point can only be moved horizontally, and is forced to always stay on the same horizontal line as the first point. The third point determines the amplitude. That point can only be moved vertically, and is forced to stay at the peak of the first crest of the sine wave. So if `(x1, y1)` is the first point, `x2` the x-coordinate of the second point, and `y3` the y-coordinate of the third point, then the function is `f(x) = y3 * sin(2 * pi / x2 * (x - x1)) + y1`. There are several new GraphTool options added to make it so that the axis labels can be multiples of `pi`. They are `scaleX`, `scaleY`, `scaleSymbolX`, and `scaleSymbolY`. The "scale" options are the scale of the ticks on the x and y axes. That is the distance between two successive ticks on the axis (including both major and minor ticks). The "scaleSymbol" options are the scale symbols for the ticks on the x and y axes. The labels on the axis will be shown as multiples of this symbol. These options can be used in combination to show tick labels at multiples of pi by using the settings `scaleX => pi->value` and `scaleSymbolX => "~~x{03C0}"`. Note that value of `scaleSymbolX` is the unicode pi symbol, and that `~~` is the PG escape character (normally a backslash in Perl). The coordinate hints in the lower right corner have also been updated to use these options if set. There is a general and minor change to some other graph objects. The "down", "up", and "drag" handlers are no longer attached to static graph object points. For most objects this doesn't matter because the points are hidden. So the points can't be clicked on or dragged in any case. However, for the "fill" graph object the paint bucket icon is still visible for static fill objects, and then clicking on the icon you see the mouse cursor disappear. The icon still can't be dragged because it is fixed, but the cursor disappearing sort of indicates that the icon has been grabbed for a drag which is somewhat counter intuitive when you can't actually do so. These handlers aren't needed for static objects in any case.
…intsType` settings. This reworks the coordinate hints code considerably. The JSXGraph `formatLabelText` method of the default axes ticks is overriden so that tick labels can be formatted according to our `coordinateHintsType` settings. Note that there is a JSXGraph tick label `toFraction` option that is similar and is used in the default `formatLabelText` method, but it always uses mixed numbers. Furthermore, the `scaleSymbol` is included in what is typeset by MathJax (the default method does not do this). This looks better and also means that instead of needing to use the unicode symbol for pi, the LaTeX `\pi` command can be used instead. Note that MathJax actually supports the unicode symbol and typesets it the same as `\pi`. So if the `coordinateHintsType` setting is 'mixed' then both the coordinate hints shown in the lower right corner of the graph (or upper left for number lines) and the labels on the axes will be shown as mixed numbers, and if the setting is 'fraction' then both will be displayed as improper fractions, and with the default 'decimal' setting both will be decimals. Note that the `useMathJax: true` and `display: 'html'` settings are now set for the axes tick labels so that fractions are displayed typeset by MathJax. Note that this is stated above for the `coordinateHintsType` setting, but really applies to the `coordinateHintsTypeX` and `coordinateHintsTypeY` settings as well for per coordinate and axis behavior. Also note that now the `coordinateHintsType` settings are perhaps not appropriately named since they apply to more than just the coordinate hints, and also apply to axis labels. But I don't feel like adding another setting for this and consistency between the hint coordinates and axis labels is better. The JSXGraph `generateLabelText` method of the axes ticks is also overridden so that zero is also typeset using MathJax. The default JSXGraph method never does this even if the other labels are typeset using MathJax and gives an inconsistent appearance in that case.
88d2ff9
to
dd5430a
Compare
A graph object can only add to the help when it is selected. The help is also updated when focus moves within the object to different defining points. So the graph object can give a different message depending on which point is focused. The sine wave tool uses this to let the user know restrictions on how the focused point can move.
Return true from the sineWaveTool updateHighlights method so that the general graphtool move handler doesn't overrided the coordinates set in the updateHighlights method. During the sine wave tool graphing phases instead of refusing to plot a point when a down event occurs and the cursor is in an invalid location, just plot the point where the highlight point currently is. Refusing to plot the point can be confusing because the highlight point looks like it is where the user wants it to be, and yet the click does nothing. This technique needs to be implemented for all of the tools. It is better than the previous method since it is more intuitive for the user.
that points can be brought to the edge.
…ve tool. For all of the graph tools switch to using the highlight point coordinates when a click occurs at an invalid location on the board for the next phase. Still refuse to create a point if a click or touch occurs off the board. This doesn't really happen for a click, but does for a touch on a touch screen device. In that case, the touch off the board should be ignored. Don't use `==` for comparison of floating point numbers.
…tions. When MathJax accessibility is enabled the tick label positions are off. Updating the board after the labels are typeset fixes this.
The tool can be added by setting
availableTools => [ 'SineWaveTool' ]
in the->with
call when creating aGraphTool
object. Of course other tools can be added in the list as well. The tool works by plotting three points. The first point determines the phase shift (or x translation) and y translation. The second point determines the amplitude. Note that point can only be moved horizontally, and is forced to always stay on the same horizontal line as the first point. The third point determines the amplitude. That point can only be moved vertically, and is forced to stay at the peak of the first crest of the sine wave. So if(x1, y1)
is the first point,x2
the x-coordinate of the second point, andy3
the y-coordinate of the third point, then the function isf(x) = y3 * sin(2 * pi / x2 * (x - x1)) + y1
.An example problem is attached: GraphSineWavePi.pg.txt
There are several new GraphTool options added to make it so that the axis labels can be multiples of
pi
. They arescaleX
,scaleY
,scaleSymbolX
, andscaleSymbolY
. The "scale" options are the scale of the ticks on the x and y axes. That is the distance between two successive ticks on the axis (including both major and minor ticks). The "scaleSymbol" options are the scale symbols for the ticks on the x and y axes. The labels on the axis will be shown as multiples of this symbol.These options can be used in combination to show tick labels at multiples of pi by using the settings
scaleX => pi->value
andscaleSymbolX => '\pi'
.The coordinate hints in the lower right corner have also been updated to use these options if set.
Also make the axis tick labels be shown according to the
coordinateHintsType
settings. This reworks the coordinate hints code considerably. The JSXGraphformatLabelText
method of the default axes ticks is overriden so that tick labels can be formatted according to ourcoordinateHintsType
settings. Note that there is a JSXGraph tick labeltoFraction
option that is similar and is used in the defaultformatLabelText
method, but it always uses mixed numbers. Furthermore, thescaleSymbol
is included in what is typeset by MathJax (the default method does not do this). This looks better and also means that instead of needing to use the unicode symbol for pi, the LaTeX\pi
command can be used instead. Note that MathJax actually supports the unicode symbol and typesets it the same as\pi
. So if thecoordinateHintsType
setting is 'mixed' then both the coordinate hints shown in the lower right corner of the graph (or upper left for number lines) and the labels on the axes will be shown as mixed numbers, and if the setting is 'fraction' then both will be displayed as improper fractions, and with the default 'decimal' setting both will be decimals. Note that theuseMathJax: true
anddisplay: 'html'
settings are now set for the axes tick labels so that fractions are displayed typeset by MathJax. Note that this is stated for thecoordinateHintsType
setting, but really applies to thecoordinateHintsTypeX
andcoordinateHintsTypeY
settings as well for per coordinate and axis behavior.Now the
coordinateHintsType
settings are perhaps not appropriately named since they apply to more than just the coordinate hints, and also apply to axis labels. But I don't feel like adding another setting for this and consistency between the hint coordinates and axis labels is better.The JSXGraph
generateLabelText
method of the axes ticks is also overridden so that zero is also typeset using MathJax. The default JSXGraph method never does this even if the other labels are typeset using MathJax and gives an inconsistent appearance in that case.Add a way for a graph object to add to the help. A graph object can only add to the help when it is selected. The help is also updated when focus moves within the object to different defining points. So the graph object can give a different message depending on which point is focused. The sine wave tool uses this to let the user know restrictions on how the focused point can move.
There is a general and minor change to some other graph objects. The "down", "up", and "drag" handlers are no longer attached to static graph object points. For most objects this doesn't matter because the points are hidden. So the points can't be clicked on or dragged in any case. However, for the "fill" graph object the paint bucket icon is still visible for static fill objects, and then clicking on the icon you see the mouse cursor disappear. The icon still can't be dragged because it is fixed, but the cursor disappearing sort of indicates that the icon has been grabbed for a drag which is somewhat counter intuitive when you can't actually do so. These handlers aren't needed for static objects in any case.
Note that JSXGraph is updated to the latest version.