-
Notifications
You must be signed in to change notification settings - Fork 227
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
Initial commit of pretty-formatter. #269
base: develop
Are you sure you want to change the base?
Conversation
Very cool; just went through the docs and got rid of a couple trivial typos. I'm not sure that this is high-quality feedback, because I'm so out of touch with text streaming, but looking through the API synopsis didn't give me much info on how to use the class. I'm wondering if a super basic a MWE front and center in the docs would be useful? (This is somewhat taken care of by the examples at the end.) (Also, forgot to add Also, any plans for unicode subscripts and superscripts? Might be required for pretty-printing polynomials. Also it would make the Got perhaps a good warning from
Next, ran it with
|
Thanks!
Yes for sure, I just haven't got there yet. But basically, almost whatever you can do to an ostream, you can do to a pretty printer instance.
I confess I hadn't realised Unicode could do that - I need to look into that, and yes spit out UTF8.
Yup, a bug, will fix. Working on polynomials now BTW: I suspect as I go along many internals will get re-written somewhat. At the moment this is more of a sketch of an idea than fully fledged, but I think it's getting there... |
…rmatting Fixed Conflicts: doc/fp_utilities/formatting.qbk
Latest version now supports polynomial types plus Unicode plain text output (though still some things to double check). Chebyshev transform I can see how to support, but the barycentric_rational, cardinal_cubic_b_spline and trigonometric interpolators I don't see what should be printed? |
Just ran it on my machine; looks great! BTW, the docs don't show how to initialize the polynomial ( Barycentric rational might be harder than I had thought, the sum over a_k/(x-x_k) really looks quite challenging without LaTeX support. The trigonometric interpolator might be able to work just like the polynomial; just take z = e^{i\theta} and don't bother to expand it into sines and cosines. That's the easy way, since the internal rep is a complex polynomial. Maybe it'd be useful to spit out sines and cosines as well. Cubic B-spline: 3.4B₃(0.01(x-1)) + 8.7B₃(0.01(x-2)) + I'll try to take a look at these. |
BTW, the unicode superscripts for n>=10 look a little bizarre on my console, but perfectly fine on Firefox:
How do they look on windows terminal? |
Every app I have tried has worked except Notepad++ where I suspect that a font change will make the superscripts about 3 work rather than a box. All browsers, edge Chrome Firefox, Opera, Word, Excel, Outllok Onenote, and Textpad all work fine. So - very pretty! |
On Linux I see the superscripts are rather spaced out, likewise on Cygwin: I believe this is an artefact of the console using a fixed width font, so although the number are shrunk down in size, their spacing remains the same. Firefox is likely using a regular variable width font and putting the superscripted numbers closers together. MSVC console is a whole other beast, and doesn't really support Unicode out (at least not be default). |
Yup you're right: It's a monospaced font problem. Quick question: The docs show a zero before the 6 on the polynomial formatting, namely 10^-06 rather than 10^-6, is this intended? I'm also getting a bizarre tilde spat out after each infinity on (I think this might be a bug in the console; when I highlighted it to copy-past, it disappeared. I think we might discover a lot of unicode-related bugs with this.) |
Sort of: the intention is to not mess with the underlying iostreams formatting, I could strip leading zeros from the exponent if it's going to look better (I suspect it will).
It's supposed to be a complex-infinity: the infinity symbol with a tilde above, so it uses the combining mark to produce that. Cygwin mucks it up s well: As do other text editors, so maybe this wasn't such a hot idea :( HTML renders the same Unicode sequence correctly though: |
How about \mathbb{C}(\infty) for complex infinity? There is also a unicode blackboard bold. (Is there any end to the scope of unicode?) |
Similarly mingw and git bash (MS DOSbox). I didn't try this assuming (correctly!) it would not work. This would work OK if the Unicode page provided a full set of superscript numbers 0 to 9. 0 to 3 are done differently, so on all these systems, the numers 4 to 9 don't display - you get a box or something instead. " PS monospacing means the display is as expected - less pretty. |
That looks dangerously close to the Riemann sphere as in https://en.wikipedia.org/wiki/Riemann_sphere. The same text just uses \infty for complex-infinity, so maybe this should do the same for plain text output? Putting a tilde on top is a Mathematica-ism BTW, I haven't been able to find any "official" guidance on how complex infinity should be typeset.
There is supposed to be a way to make this work on a Windows console - cygwin manages it after all, it's "just" a question of getting the right code-page loaded. |
Yup, that's the goal! I remember my complex analysis class demonstrating the automorphism between the sphere and the plane; the takeaway being "there is only one complex infinity".
I think that is a perfectly sensible option. I actually like Mathematica's notation here; sadly non-LaTeX mathematical text rendering is still in the stone-age. In any case, the more I think about it, the more I feel like pretty-printing is a hugely important task for the library. For instance, reading through the docs to find out what scaling convention is used for some object is actually pretty challenging; way easier just to print it. |
Get windows console output working.
@pabristow : Printing to the windows console works (mostly) fine if you add:
At the start of main. There are a couple of (seldom used) symbols that seem to be unsupported - maybe this is fixable by changing the console font (or not), but all the defaults work fine including all the super/sub scripts. |
I've managed to get a really bush-league implementation of the pretty-printer working for the In any case, here's the code:
friend std::ostream& operator<<(std::ostream& os, const cardinal_cubic_b_spline_imp<Real>& spline) {
os << spline.m_avg << "+";
for (int64_t k = 0; k < int64_t(spline.m_beta.size()); ++k) {
os << spline.m_beta[k] << "×B₃(" << spline.m_h_inv << "(x-" << spline.m_a << ") + " << 1 - k << ") + ";
}
return os;
} (Obviously haven't implemented the lookahead to see if I should put a
friend std::ostream& operator<<(std::ostream& os, const cardinal_cubic_b_spline<Real>& spline) {
os << *spline.m_imp;
return os;
} Currently looks like this:
but I hope to get it to:
Test program:
#include <iostream>
#include <vector>
#include <boost/math/interpolators/cardinal_cubic_b_spline.hpp>
int main() {
std::vector<double> v(10);
for (size_t i = 0; i < v.size(); ++i)
{
v[i] = 5 + 6*i;
}
double step = 0.1;
double a = 5;
boost::math::interpolators::cardinal_cubic_b_spline<double> spline(v.data(), v.size(), a, step);
std::cout << spline;
} |
The issue here is that formatter.hpp relies on public API's of the types being formatted, but the interpolators don't expose their internals. Conversely, the formatters have some very ad-hoc code in them - which is fine if you just want to format the basic number types - but types which are really general purpose expressions then get a lot more difficult. So I guess the question is whether the formatters should be re-worked into something more like an expression-printer complete with symbolic representations of arbitrary expressions? It's certainly do-able, probably very useful and logical, but I confess way more work than I thought I was taking on ;) |
Would it be less work to just do a collection of one-offs for each interpolator/object we want to print? Obviously it's not ideal but nonetheless it could still work if we all decided to build this expertise together. |
I think so.... what if I do a bit of refactoring and expose a public API for printing various symbols plus super/subscripts etc? Then outputting a "special" type would just be a sequence of function calls to format the various components? |
I also note that the code page can be set in the registry (65001 for UTF-8) but I haven't dared try this yet. Computer\HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Nls\CodePage May have other side effects? |
I like this idea; and will test it out with the B-spline once it's ready. |
Add cubic B spline as example.
OK docs for the formatting API were done in a tad of a hurry, but the basics are all there I hope. Implemented cubic B spline printing using the API (but feel free to change). Plain text output: 32 - 33×B₃(10(x - 5) + 1) - 27×B₃(10(x - 5)) - 21×B₃(10(x - 5) - 1) - 15×B₃(10(x - 5) - 2) - 9×B₃(10(x - 5) - 3) - 3×B₃(10(x - 5) - 4) + 3×B₃(10(x - 5) - 5) + 9×B₃(10(x - 5) - 6) + 15×B₃(10(x - 5) - 7) + 21×B₃(10(x - 5) - 8) + 27×B₃(10(x - 5) - 9) + 33×B₃(10(x - 5) - 10) HTML output: 32 - 33×B3(10(x - 5) + 1) - 27×B3(10(x - 5)) - 21×B3(10(x - 5) - 1) - 15×B3(10(x - 5) - 2) - 9×B3(10(x - 5) - 3) - 3×B3(10(x - 5) - 4) + 3×B3(10(x - 5) - 5) + 9×B3(10(x - 5) - 6) + 15×B3(10(x - 5) - 7) + 21×B3(10(x - 5) - 8) + 27×B3(10(x - 5) - 9) + 33×B3(10(x - 5) - 10) |
Looks awesome! One quick comment with the B-spline: Do you think it would like better with your 'cdot', namely: 32 - 33·B₃(10(x - 5) + 1) - 27·B₃(10(x - 5)) - 21·B₃(10(x - 5) - 1) - 15·B₃(10(x - 5) - 2) - 9·B₃(10(x - 5) - 3) ... Also, just ran it on Mac, read through the docs, built the examples with sanitizers; no problems on my end. Also, not sure if this is something to worry about, but when compiling with sanitizers it seems to take quite a while:
Without the sanitizers it take ~11 seconds, which seems fine. |
Perhaps... but we need to pick one as the default, after that the user can choose which they prefer by using the manipulators?
Yikes, that is a long time! The file does instantiate a heck of a lot of stuff though, including some multiprecision types. However if I restrict it to integer and floating point types, and remove the multiprecision stuff, the compile time drops to ~ 1s for me even with the sanitizers on. |
The long compile time is a gcc artifact, I see:
But if I remove the -O2 -ffast-math I get:
Things are similarly improved if I remove the -g but keep the optimizations, or indeed if I just use clang. |
Yeah, just looking at it again makes me realize that this is less of an unambiguous win than I thought it was. Sorry for the bikeshedding; keep the eye on the prize: This allows users to easily verify that their mental representation of their object is the same as ours.
Yeah, |
Ugh looks like you’ve probably uncovered a bug in the quadratic and quintic B spline interpolators, it’s spitting out nans |
The (very basic) example is OK for me, or is this with something else? BTW can you check that I've documented the splines correctly - particularly how many points they include when interpolating? Thanks! |
Here's what I get on Mac OS, zsh:
Same thing with the quintic B-spline. Update: I figured this one out, my fault: It's the |
Your comment is:
I would state it differently: "Despite appearances, only a few terms of the sum are nonzero, since the basis function B_n has compact support." The actual number of non-zero terms for a given abscissa is fairly complicated to derive. |
Hmm, on cygwin I see: -B₂(10(x - 5) + 1) + 5×B₂(10(x - 5)) + 11×B₂(10(x - 5) - 1) + 17×B₂(10(x - 5) - 2) + 23×B₂(10(x - 5) - 3) + 29×B₂(10(x - 5) - 4) + 35×B₂(10(x - 5) - 5) + 41×B₂(10(x - 5) - 6) + 47×B₂(10(x - 5) - 7) + 53×B₂(10(x - 5) - 8) + 59×B₂(10(x - 5) - 9) + 65×B₂(10(x - 5) - 10) For the quartic, and for the quintic: -7×B₅(10(x - 5) + 2) - B₅(10(x - 5) + 3) + 5×B₅(10(x - 5) + 4) + 11×B₅(10(x - 5) + 5) + 17×B₅(10(x - 5) + 6) + 23×B₅(10(x - 5) + 7) + 29×B₅(10(x - 5) + 8) + 35×B₅(10(x - 5) + 9) + 41×B₅(10(x - 5) + 10) + 47×B₅(10(x - 5) + 11) + 53×B₅(10(x - 5) + 12) + 59×B₅(10(x - 5) + 13) + 65×B₅(10(x - 5) + 14) + 71×B₅(10(x - 5) + 15) |
Tidy up some std::isnan usage to prevent macro expansion.
The only difference I see with the quadratic and quintic B spline is that they use std::isnan rather than boost::math::isnan. It really shouldn't make any difference, but just in case I've pushed a fix to prevent macro expansion of isnan. Wild idea: are you using -ffast-math? I wonder if the compiler is optimising the call away (assuming it's seeing "x != x" or similar) and so isnan is always false? |
Barycentric rational support added - it's a bit verbose and hard to read unless you use LaTex output, but it does work. Plain text: P⁽ˣ⁾⁄Q₍ₓ₎ ; P(x) = ⁵⋅⁶²⁶×⁻²⁰⁸³³⋅³⁄₍ₓ ₋ ₀.₀₂₎ + ⁵⋅⁵⁴⁴×⁸³³³³⋅³⁄₍ₓ ₋ ₀.₀₄₎ + ⁵⋅⁴⁵×⁻¹⁴⁵⁸³³⁄₍ₓ ₋ ₀.₀₆₎ + ⁵⋅³⁵¹×¹⁶⁶⁶⁶⁶⁄₍ₓ ₋ ₀.₀₈₎ + ⁵⋅²⁵³×⁻¹⁶⁶⁶⁶⁶⁄₍ₓ ₋ ₀.₁₎ + ⁵⋅¹⁵⁶×¹⁶⁶⁶⁶⁶⁄₍ₓ ₋ ₀.₁₂₎ + ⁵⋅⁰⁵⁸×⁻¹⁶⁶⁶⁶⁶⁄₍ₓ ₋ ₀.₁₄₎ + ⁴⋅⁹⁶×¹⁶¹⁴⁵⁸⁄₍ₓ ₋ ₀.₁₆₎ + ⁴⋅⁸⁶²×⁻¹³³³³³⁄₍ₓ ₋ ₀.₁₈₎ + ⁴⋅⁶⁶²×⁶⁰³¹²⋅⁵⁄₍ₓ ₋ ₀.₂₎ + ⁴⋅⁵⁶³×⁻²⁶⁰⁴¹⋅⁶⁄₍ₓ ₋ ₀.₂₄₎ + ⁴⋅³⁶ײ¹³⁵⁴⋅²⁄₍ₓ ₋ ₀.₂₈₎ + ⁴⋅¹⁵⁸⁴×⁻²⁰⁸³³⋅³⁄₍ₓ ₋ ₀.₃₂₎ + ³⋅⁹⁴⁶³×²⁰⁸³³⋅³⁄₍ₓ ₋ ₀.₃₆₎ + ³⋅⁶³⁶×⁻²⁰⁸³³⋅³⁄₍ₓ ₋ ₀.₄₎ + ³⋅⁵⁴²⁹ײ⁰⁸³³⋅³⁄₍ₓ ₋ ₀.₄₄₎ + ³⋅³⁶⁹⁶×⁻²⁰⁸³³⋅³⁄₍ₓ ₋ ₀.₄₈₎ + ³⋅²⁴¹⁶ײ⁰¹⁸²⋅³⁄₍ₓ ₋ ₀.₅₂₎ + ³⋅¹²⁰⁹×⁻¹⁶⁶⁶⁶⋅⁶⁄₍ₓ ₋ ₀.₅₆₎ + ³⋅⁰¹³⁸×⁸⁶⁸⁹⋅⁰⁶⁄₍ₓ ₋ ₀.₆₎ + ²⋅⁸³⁴²×⁻³²⁵⁵⋅²¹⁄₍ₓ ₋ ₀.₆₈₎ + ²⋅⁶⁸⁸¹×²⁶⁶⁹⋅²⁶⁄₍ₓ ₋ ₀.₇₆₎ + ²⋅⁵⁶⁶²×⁻²⁶⁰⁴⋅¹⁶⁄₍ₓ ₋ ₀.₈₄₎ + ²⋅⁴²⁴²×²⁶⁰⁴⋅¹⁶⁄₍ₓ ₋ ₀.₉₂₎ + ²⋅³⁶⁶⁶×⁻²⁶⁰⁴⋅¹⁶⁄₍ₓ ₋ ₁₎ + ²⋅³⁰⁵⁸ײ⁶⁰⁴⋅¹⁶⁄₍ₓ ₋ ₁.₀₈₎ + ²⋅²⁴⁵⁸×⁻²⁶⁰⁴⋅¹⁶⁄₍ₓ ₋ ₁.₁₆₎ + ²⋅²⁰³⁵ײ⁶⁰⁴⋅¹⁶⁄₍ₓ ₋ ₁.₂₄₎ + ²⋅¹⁶⁶¹×⁻²⁵²²⋅⁶⁹⁄₍ₓ ₋ ₁.₃₂₎ + ²⋅¹³⁵ײ⁰⁸³⋅³³⁄₍ₓ ₋ ₁.₄₎ + ²⋅¹⁰⁹×⁻¹⁰⁹⁸⋅⁶³⁄₍ₓ ₋ ₁.₄₈₎ + ²⋅⁰⁶⁹⁶×⁴⁰⁶⋅⁹⁰¹⁄₍ₓ ₋ ₁.₆₄₎ + ²⋅⁰⁴⁶⁶×⁻³³³⋅⁶⁵⁹⁄₍ₓ ₋ ₁.₈₎ + ²⋅⁰³²⁵׳²⁵⋅⁵²¹⁄₍ₓ ₋ ₁.₉₆₎ + ²⋅⁰²⁸⁸×⁻³²⁵⋅⁵²¹⁄₍ₓ ₋ ₂.₁₂₎ + ²⋅⁰²⁹²×³²⁵⋅⁵²¹⁄₍ₓ ₋ ₂.₂₈₎ + ²⋅⁰²²⁸×⁻³²⁵⋅⁵²¹⁄₍ₓ ₋ ₂.₄₄₎ + ²⋅⁰¹²⁴׳²⁵⋅⁵²¹⁄₍ₓ ₋ ₂.₆₎ + ²⋅⁰⁰⁶⁵×⁻³²⁵⋅⁵²¹⁄₍ₓ ₋ ₂.₇₆₎ + ²⋅⁰⁰³¹×³²⁵⋅⁵²¹⁄₍ₓ ₋ ₂.₉₂₎ + ²⋅⁰⁰¹⁵×⁻³²⁵⋅⁵²¹⁄₍ₓ ₋ ₃.₀₈₎ + ²⋅⁰⁰⁰⁸׳²⁵⋅⁵²¹⁄₍ₓ ₋ ₃.₂₄₎ + ²⋅⁰⁰⁰⁴×⁻²⁸⁴⋅⁸³¹⁄₍ₓ ₋ ₃.₄₎ + ²⋅⁰⁰⁰²×¹⁶²⋅⁶⁶⁄₍ₓ ₋ ₃.₅₆₎ + ²⋅⁰⁰⁰¹×⁻⁴⁰⋅⁶⁹⁰¹⁄₍ₓ ₋ ₃.₇₂₎ ∧ Q(x) = ⁵⋅⁶²⁶⁄₍ₓ ₋ ₀.₀₂₎ + ⁵⋅⁵⁴⁴⁄₍ₓ ₋ ₀.₀₄₎ + ⁵⋅⁴⁵⁄₍ₓ ₋ ₀.₀₆₎ + ⁵⋅³⁵¹⁄₍ₓ ₋ ₀.₀₈₎ + ⁵⋅²⁵³⁄₍ₓ ₋ ₀.₁₎ + ⁵⋅¹⁵⁶⁄₍ₓ ₋ ₀.₁₂₎ + ⁵⋅⁰⁵⁸⁄₍ₓ ₋ ₀.₁₄₎ + ⁴⋅⁹⁶⁄₍ₓ ₋ ₀.₁₆₎ + ⁴⋅⁸⁶²⁄₍ₓ ₋ ₀.₁₈₎ + ⁴⋅⁶⁶²⁄₍ₓ ₋ ₀.₂₎ + ⁴⋅⁵⁶³⁄₍ₓ ₋ ₀.₂₄₎ + ⁴⋅³⁶⁄₍ₓ ₋ ₀.₂₈₎ + ⁴⋅¹⁵⁸⁴⁄₍ₓ ₋ ₀.₃₂₎ + ³⋅⁹⁴⁶³⁄₍ₓ ₋ ₀.₃₆₎ + ³⋅⁶³⁶⁄₍ₓ ₋ ₀.₄₎ + ³⋅⁵⁴²⁹⁄₍ₓ ₋ ₀.₄₄₎ + ³⋅³⁶⁹⁶⁄₍ₓ ₋ ₀.₄₈₎ + ³⋅²⁴¹⁶⁄₍ₓ ₋ ₀.₅₂₎ + ³⋅¹²⁰⁹⁄₍ₓ ₋ ₀.₅₆₎ + ³⋅⁰¹³⁸⁄₍ₓ ₋ ₀.₆₎ + ²⋅⁸³⁴²⁄₍ₓ ₋ ₀.₆₈₎ + ²⋅⁶⁸⁸¹⁄₍ₓ ₋ ₀.₇₆₎ + ²⋅⁵⁶⁶²⁄₍ₓ ₋ ₀.₈₄₎ + ²⋅⁴²⁴²⁄₍ₓ ₋ ₀.₉₂₎ + ²⋅³⁶⁶⁶⁄₍ₓ ₋ ₁₎ + ²⋅³⁰⁵⁸⁄₍ₓ ₋ ₁.₀₈₎ + ²⋅²⁴⁵⁸⁄₍ₓ ₋ ₁.₁₆₎ + ²⋅²⁰³⁵⁄₍ₓ ₋ ₁.₂₄₎ + ²⋅¹⁶⁶¹⁄₍ₓ ₋ ₁.₃₂₎ + ²⋅¹³⁵⁄₍ₓ ₋ ₁.₄₎ + ²⋅¹⁰⁹⁄₍ₓ ₋ ₁.₄₈₎ + ²⋅⁰⁶⁹⁶⁄₍ₓ ₋ ₁.₆₄₎ + ²⋅⁰⁴⁶⁶⁄₍ₓ ₋ ₁.₈₎ + ²⋅⁰³²⁵⁄₍ₓ ₋ ₁.₉₆₎ + ²⋅⁰²⁸⁸⁄₍ₓ ₋ ₂.₁₂₎ + ²⋅⁰²⁹²⁄₍ₓ ₋ ₂.₂₈₎ + ²⋅⁰²²⁸⁄₍ₓ ₋ ₂.₄₄₎ + ²⋅⁰¹²⁴⁄₍ₓ ₋ ₂.₆₎ + ²⋅⁰⁰⁶⁵⁄₍ₓ ₋ ₂.₇₆₎ + ²⋅⁰⁰³¹⁄₍ₓ ₋ ₂.₉₂₎ + ²⋅⁰⁰¹⁵⁄₍ₓ ₋ ₃.₀₈₎ + ²⋅⁰⁰⁰⁸⁄₍ₓ ₋ ₃.₂₄₎ + ²⋅⁰⁰⁰⁴⁄₍ₓ ₋ ₃.₄₎ + ²⋅⁰⁰⁰²⁄₍ₓ ₋ ₃.₅₆₎ + ²⋅⁰⁰⁰¹⁄₍ₓ ₋ ₃.₇₂₎ HTML: P(x)⁄Q(x) ; P(x) = 5.727×-20833.3⁄(x - 0.02) + 5.544×83333.3⁄(x - 0.04) + 5.45×-145833⁄(x - 0.06) + 5.351×166667⁄(x - 0.08) + 5.253×-166667⁄(x - 0.1) + 5.157×166667⁄(x - 0.12) + 5.058×-166667⁄(x - 0.14) + 4.96×161458⁄(x - 0.16) + 4.862×-133333⁄(x - 0.18) + 4.762×70312.5⁄(x - 0.2) + 4.563×-26041.7⁄(x - 0.24) + 4.36×21354.2⁄(x - 0.28) + 4.1584×-20833.3⁄(x - 0.32) + 3.9463×20833.3⁄(x - 0.36) + 3.736×-20833.3⁄(x - 0.4) + 3.5429×20833.3⁄(x - 0.44) + 3.3797×-20833.3⁄(x - 0.48) + 3.2417×20182.3⁄(x - 0.52) + 3.1209×-16666.7⁄(x - 0.56) + 3.0138×8789.06⁄(x - 0.6) + 2.8342×-3255.21⁄(x - 0.68) + 2.6881×2669.27⁄(x - 0.76) + 2.5662×-2604.17⁄(x - 0.84) + 2.4242×2604.17⁄(x - 0.92) + 2.3766×-2604.17⁄(x - 1) + 2.3058×2604.17⁄(x - 1.08) + 2.2458×-2604.17⁄(x - 1.16) + 2.2035×2604.17⁄(x - 1.24) + 2.1661×-2522.79⁄(x - 1.32) + 2.135×2083.33⁄(x - 1.4) + 2.109×-1098.63⁄(x - 1.48) + 2.0697×406.901⁄(x - 1.64) + 2.0466×-333.659⁄(x - 1.8) + 2.0325×325.521⁄(x - 1.96) + 2.0288×-325.521⁄(x - 2.12) + 2.0292×325.521⁄(x - 2.28) + 2.0228×-325.521⁄(x - 2.44) + 2.0124×325.521⁄(x - 2.6) + 2.0065×-325.521⁄(x - 2.76) + 2.0031×325.521⁄(x - 2.92) + 2.0015×-325.521⁄(x - 3.08) + 2.0008×325.521⁄(x - 3.24) + 2.0004×-284.831⁄(x - 3.4) + 2.0002×162.76⁄(x - 3.56) + 2.0001×-40.6901⁄(x - 3.72) ∧ Q(x) = 5.727⁄(x - 0.02) + 5.544⁄(x - 0.04) + 5.45⁄(x - 0.06) + 5.351⁄(x - 0.08) + 5.253⁄(x - 0.1) + 5.157⁄(x - 0.12) + 5.058⁄(x - 0.14) + 4.96⁄(x - 0.16) + 4.862⁄(x - 0.18) + 4.762⁄(x - 0.2) + 4.563⁄(x - 0.24) + 4.36⁄(x - 0.28) + 4.1584⁄(x - 0.32) + 3.9463⁄(x - 0.36) + 3.736⁄(x - 0.4) + 3.5429⁄(x - 0.44) + 3.3797⁄(x - 0.48) + 3.2417⁄(x - 0.52) + 3.1209⁄(x - 0.56) + 3.0138⁄(x - 0.6) + 2.8342⁄(x - 0.68) + 2.6881⁄(x - 0.76) + 2.5662⁄(x - 0.84) + 2.4242⁄(x - 0.92) + 2.3766⁄(x - 1) + 2.3058⁄(x - 1.08) + 2.2458⁄(x - 1.16) + 2.2035⁄(x - 1.24) + 2.1661⁄(x - 1.32) + 2.135⁄(x - 1.4) + 2.109⁄(x - 1.48) + 2.0697⁄(x - 1.64) + 2.0466⁄(x - 1.8) + 2.0325⁄(x - 1.96) + 2.0288⁄(x - 2.12) + 2.0292⁄(x - 2.28) + 2.0228⁄(x - 2.44) + 2.0124⁄(x - 2.6) + 2.0065⁄(x - 2.76) + 2.0031⁄(x - 2.92) + 2.0015⁄(x - 3.08) + 2.0008⁄(x - 3.24) + 2.0004⁄(x - 3.4) + 2.0002⁄(x - 3.56) + 2.0001⁄(x - 3.72) LaTex: |
Yup that was it. The barycentric rational might be helped in presentation (for the example) by use of something shorter, but your idea of splitting up the numerator and denominator looks exactly right. |
I thought this was a gcc bug, but a quick Google and apparently -ffast-math turns on -ffinite-math-only and removes all support for infinities and NaN's :( |
@NAThompson : how does the data stored inside the Cardinal Trig interpolator relate to the coefficients of the sines and cosines? |
@jzmaddock : Internally, it's just a polynomial. So you set z = e^{i\theta} to do the evaluation by Horner's method (see interpolators/detail/cardinal_trigonometric_detail.hpp:102) and you get q(t) = \gamma_0 +2Re{ \sum_{k = 1}^{N-1} \gamma_{k}z^{k}} That's the internal representation. Another, perhaps better representation for the user might be q(t) = \gamma_0 + 2Re{\sum_{k=1}^{N-1} \gamma_{k}\exp(2\pi i k (t-t_0)/T)} where \gamma_k, t_0, and T are numerical parameters passed by the user. Is it desirable to turn this into sines and cosines? Just gotta use de Moivre and break \gamma_k into real and imaginary parts. |
This still needs lots of work, but is starting to look useful, initial commit posted here for discussion.