663fbcfdcb4f8.gif

Anybody know how to do this?

![663fbcfdcb4f8.gif](serve/attachment&path=663fbcfdcb4f8.gif) Anybody know how to do this?
 
0
reply

Interesting link

Seams he had the same idea i mentioned in
https://www.ultrafractal.com/forum/index.php?u=/topic/925/rotation-in-formula/1#post-3001

https://mathr.co.uk/blog/2013-12-16_stretching_cusps.html

.

I ask my self if he found a solution for the bulb size.
It could be that Feigenbaums bifurcation could play a role there...

Interesting link Seams he had the same idea i mentioned in https://www.ultrafractal.com/forum/index.php?u=/topic/925/rotation-in-formula/1#post-3001 https://mathr.co.uk/blog/2013-12-16_stretching_cusps.html . I ask my self if he found a solution for the bulb size. It could be that Feigenbaums bifurcation could play a role there...
 
0
reply

He's active in the Fractal Chats discord, feel free to join. Lots of happy nerd stuff going on there. Here's the invite link in case you are interested.

https://discord.gg/DrxFcsRA

Everyone else is welcome too, ofc! smile

He's active in the Fractal Chats discord, feel free to join. Lots of happy nerd stuff going on there. Here's the invite link in case you are interested. https://discord.gg/DrxFcsRA Everyone else is welcome too, ofc! :)
 
0
reply

Tanks much!
(I am not a mathematician, not sure if they want me there...)

I found in his codes a solution for the bulb size correction, in case you are still interested.
https://github.com/adammaj1/Mandelbrot-book-book


There is a algo in m_nucleus, it searches the center of a bulb. With the center and the base of the bulb the size is calculable, even if the bulbs are not perfect circles.
with this size estimation
sin(pi * n/d) / (d ^ 2)
you can define the c0 as a start for the search, it comes actually very close.

(There is probable a more elegant way to calculate the bulb size, and my codes are ugly as hell, but for now i solve a problem after 35 years i tried the first time...)

Tanks much! (I am not a mathematician, not sure if they want me there...) I found in his codes a solution for the bulb size correction, in case you are still interested. https://github.com/adammaj1/Mandelbrot-book-book There is a algo in m_nucleus, it searches the center of a bulb. With the center and the base of the bulb the size is calculable, even if the bulbs are not perfect circles. with this size estimation sin(pi * n/d) / (d ^ 2) you can define the c0 as a start for the search, it comes actually very close. (There is probable a more elegant way to calculate the bulb size, and my codes are ugly as hell, but for now i solve a problem after 35 years i tried the first time...)
 
0
reply

The code is public, it just took some search effort.
https://mathr.co.uk/source-codes/mandelbrot-numerics.pdf
https://mathr.co.uk/source-codes/mandelbrot-graphics.pdf
https://mathr.co.uk/source-codes/mandelbrot-web.pdf
etc (insert name-of-include in the pdf filename)

The code is public, it just took some search effort. https://mathr.co.uk/source-codes/mandelbrot-numerics.pdf https://mathr.co.uk/source-codes/mandelbrot-graphics.pdf https://mathr.co.uk/source-codes/mandelbrot-web.pdf etc (insert name-of-include in the pdf filename)
 
0
reply

huu, i was searching around the website but i missed the pdfs, tanks!

huu, i was searching around the website but i missed the pdfs, tanks!
 
0
reply

In the end, mathr.co.uk didn't help me one iota.

How I tackled this is first by taking the transform pdf.uxf/pgd_UnrollCardioid

It has a very simple formula (1 - sqr((0,1)*(4/(#pixel-(0,2))-(0,1))-1))/4

This is only one-way, but I experimented with every value in it a bit, and decided it was easiest to leave it, especially since WolframAlpha managed to simplify it to something as small as 1/sqr(#pixel) + 1/4. Notice here that 1/4 is the center of the cardioid, so I replaced it with a param.

Then the search for the inverse of that formula started, and it was just a matter of reversing the operations, and taking into account that a square root has two answers (this bit me at first, but visually stacking the forward and reverse transforms made clear the domain split was on the X axis): ±sqrt(1/(#pixel - @center))

Finally, rotation is simply horizontal shifting of the unrolled cardioid, so I added that as a conditional variable, only visible when the transform is in 'reverse' mode. This made clear that either (or both) transforms were inverted along the Y axis (in mandelbrot space) or X axis (in unrolled space). Actually it was both, and had to add a temp variable that inverted the shift if it was in the upper-right or lower-left quadrant.

666e1349938c1.gif

unroll-test {
::J36s9jn29OVzuxJMQ47Ix7glz5l1wCLZTlliSbO2LdfAq8iHA3Ysp2DJ72n+OQJbialq6pyJ
  br57n5bYaDqGUZvLNhxQDaBJfyF8W7GEiIn9iRj9ybFCWPY66xljW1FIEl5s2gaAiyyaW7YU
  WNTSTA0GMK5/wPs50H2vNf/2CRRJPNZB2iSNqR04dS+Dqmn6C+Jnmz8jqGDeRmTKMAYvXLHm
  soZUFjpJDqxRjr7XwBHCB5ms6qtUtqOnMPb3/83SvGUuYrPMElFpJXvtQfrxCOqxk8hvpZjB
  zzKEymO3yZkwhLS+nVONYPF84HVBtxb0fxjq5WiPTw4XXdoIrgcYmgeJAPTZGIvAx5beUyF3
  fj44xdUXc/Nll57F8/rOx5XNC9caysmTW1isDqzmZQFVU9QopHaeSSTpu+35ojIJNpZ2U7wi
  W/hj4E/RUFIF2OL8o/lZSXOfSZs+JUmXcbaixFNa4u3mLUZOvDYRv1ollFHKPIyr3T2kwctW
  NQ4ofY4lLBZlYNGfk/GNxvHYBYEUIx4fJSbsXj0HAka+PZIr7agHjoZQh+waeu2EzRWXQpNE
  oFzEH8eaThC1w6Ag2PMUUcWKYNernmBr33d4w6L57rrrLypFn1f+/NqeF/rrGFVUp/UfQxy0
}

mjd_private.uxf:MandelbrotCardioidRotation {
; Transforms between Mandelbrot's cardioid coordinates <-> cartesian coordinates.
;
; 20240615 Mark jeronimus <mark.jeronimus@gmail.com>
::wtUIvhn2NGVyONMMQ07Ix/wQ4SCQaTRiLgKEpeGhEifgpxjLWyxOMxg4zH7k4sIyhezzybZe
  2xopVa56Hv8CAUS4qSm+h4WKUDw1NqfJNsH2tt9LOtvMDuFKrIjj4wWkOutUbRHwWXfpnOmQ
  dE1Nqa80IFPvHK6XDCI8SUOCcix4s8ZDNClcVBWw5oz9+2lub7wSQe06ZhzYVJHhmfmYjOa4
  hgk43aXXk6UON5pK5V0II9xw5cAZhyqEwHx0PJsaDyYNMlrAUhNOl1EgfordSf/BB89TL2c/
  D3BFbKygnejVnUGwKB3nEMTQJjVOUPYxOdmEcx/9MFfvv/L/TTJOkVrwVMSm78416HihmJxU
  DPqJR3H/cLMJk/qWKzfAvg7w5A==
}

mjd_private.ucl:BetterDistanceEstimator(OUTSIDE) {
;
; Written by Damien M. Jones
; Improved by Mark Jeronimus
;
::EK4X7in21AVwqNMMM07By/gI5SaXX7yOOYwYsub72OOKomo0YwxKzWm12v+pY3a8B/kevney
  GnRepsAgOea2Snh+rwrQT7G4pVlFWmnTdTVfbm/j8wao+6hmM4x2VKW7+A0WWMYcoNxv246V
  zUny8Wb5TNd4xQT91VLSu/G2lf2rlP00uLTfhR4Xv0UPhncaQ6pBMazJVMilUrrenERzzHmg
  guOC2HEzEKsvah2M6xJIZ3CU3QcWMsbR5+zzsjcSVuzN31OPv9pcpRjbBX99oJAhROa7hjEE
  IBEG0p0NCyIB0NnAeIh/JL/+Zg9TRLCX4IgeCiBj70W4T2Dfh6Xk9onlNqSdK6NGio1eRjRK
  ZkrPtFlF/znO9JL=
}

NB: My BetterDistanceEstimator isn't related to this transformation. I'm just animating the density along with the rotation.

In the end, mathr.co.uk didn&#039;t help me one iota. How I tackled this is first by taking the transform **pdf.uxf/pgd_UnrollCardioid** It has a very simple formula `(1 - sqr((0,1)*(4/(#pixel-(0,2))-(0,1))-1))/4` This is only one-way, but I experimented with every value in it a bit, and decided it was easiest to leave it, especially since WolframAlpha managed to simplify it to something as small as `1/sqr(#pixel) + 1/4`. Notice here that 1/4 is the center of the cardioid, so I replaced it with a param. Then the search for the inverse of that formula started, and it was just a matter of reversing the operations, and taking into account that a square root has two answers (this bit me at first, but visually stacking the forward and reverse transforms made clear the domain split was on the X axis): `&plusmn;sqrt(1/(#pixel - @center))` Finally, rotation is simply horizontal shifting of the unrolled cardioid, so I added that as a conditional variable, only visible when the transform is in &#039;reverse&#039; mode. This made clear that either (or both) transforms were inverted along the Y axis (in mandelbrot space) or X axis (in unrolled space). Actually it was both, and had to add a temp variable that inverted the shift if it was in the upper-right or lower-left quadrant. ![666e1349938c1.gif](serve/attachment&amp;path=666e1349938c1.gif) ```` unroll-test { ::J36s9jn29OVzuxJMQ47Ix7glz5l1wCLZTlliSbO2LdfAq8iHA3Ysp2DJ72n+OQJbialq6pyJ br57n5bYaDqGUZvLNhxQDaBJfyF8W7GEiIn9iRj9ybFCWPY66xljW1FIEl5s2gaAiyyaW7YU WNTSTA0GMK5/wPs50H2vNf/2CRRJPNZB2iSNqR04dS+Dqmn6C+Jnmz8jqGDeRmTKMAYvXLHm soZUFjpJDqxRjr7XwBHCB5ms6qtUtqOnMPb3/83SvGUuYrPMElFpJXvtQfrxCOqxk8hvpZjB zzKEymO3yZkwhLS+nVONYPF84HVBtxb0fxjq5WiPTw4XXdoIrgcYmgeJAPTZGIvAx5beUyF3 fj44xdUXc/Nll57F8/rOx5XNC9caysmTW1isDqzmZQFVU9QopHaeSSTpu+35ojIJNpZ2U7wi W/hj4E/RUFIF2OL8o/lZSXOfSZs+JUmXcbaixFNa4u3mLUZOvDYRv1ollFHKPIyr3T2kwctW NQ4ofY4lLBZlYNGfk/GNxvHYBYEUIx4fJSbsXj0HAka+PZIr7agHjoZQh+waeu2EzRWXQpNE oFzEH8eaThC1w6Ag2PMUUcWKYNernmBr33d4w6L57rrrLypFn1f+/NqeF/rrGFVUp/UfQxy0 } mjd_private.uxf:MandelbrotCardioidRotation { ; Transforms between Mandelbrot&#039;s cardioid coordinates &lt;-&gt; cartesian coordinates. ; ; 20240615 Mark jeronimus &lt;mark.jeronimus@gmail.com&gt; ::wtUIvhn2NGVyONMMQ07Ix/wQ4SCQaTRiLgKEpeGhEifgpxjLWyxOMxg4zH7k4sIyhezzybZe 2xopVa56Hv8CAUS4qSm+h4WKUDw1NqfJNsH2tt9LOtvMDuFKrIjj4wWkOutUbRHwWXfpnOmQ dE1Nqa80IFPvHK6XDCI8SUOCcix4s8ZDNClcVBWw5oz9+2lub7wSQe06ZhzYVJHhmfmYjOa4 hgk43aXXk6UON5pK5V0II9xw5cAZhyqEwHx0PJsaDyYNMlrAUhNOl1EgfordSf/BB89TL2c/ D3BFbKygnejVnUGwKB3nEMTQJjVOUPYxOdmEcx/9MFfvv/L/TTJOkVrwVMSm78416HihmJxU DPqJR3H/cLMJk/qWKzfAvg7w5A== } mjd_private.ucl:BetterDistanceEstimator(OUTSIDE) { ; ; Written by Damien M. Jones ; Improved by Mark Jeronimus ; ::EK4X7in21AVwqNMMM07By/gI5SaXX7yOOYwYsub72OOKomo0YwxKzWm12v+pY3a8B/kevney GnRepsAgOea2Snh+rwrQT7G4pVlFWmnTdTVfbm/j8wao+6hmM4x2VKW7+A0WWMYcoNxv246V zUny8Wb5TNd4xQT91VLSu/G2lf2rlP00uLTfhR4Xv0UPhncaQ6pBMazJVMilUrrenERzzHmg guOC2HEzEKsvah2M6xJIZ3CU3QcWMsbR5+zzsjcSVuzN31OPv9pcpRjbBX99oJAhROa7hjEE IBEG0p0NCyIB0NnAeIh/JL/+Zg9TRLCX4IgeCiBj70W4T2Dfh6Xk9onlNqSdK6NGio1eRjRK ZkrPtFlF/znO9JL= } ```` NB: My BetterDistanceEstimator isn&#039;t related to this transformation. I&#039;m just animating the density along with the rotation.
edited Jun 15 '24 at 11:35 pm
 
0
reply

Ohh, Tans much! i could not get it done until now.

(You have to be a skilled mathematician to get attention i think.)

I had my time with the distance coloring too. Here is my variant. The hard one should not need to much correction over rotation.
(i translate it from CP, but should work.)

mjd_private.ucl:BetterDistanceEstimatorNew(OUTSIDE) {

init:
  complex dz = (1, 0)
loop:
;  dz = @power * #z^(@power-1) * dz + 1
  dz = (dz * #z ^ (@power - 1) * @power) + 0

final:
;  #index = (@power*log(cabs(#z)) * cabs(#z) / cabs(dz))^(1/@power) * sqrt(#magn)

float value
if (@distance == "Soft")
    value = (real(@power) * log(cabs(#z)) * cabs(#z) / cabs(dz) * #magn) ^ (1 / real(@power))
    value = sqrt(value) * @density
else
    dz = @power * #z * log(cabs(#z)) / dz
    value = cabs(dz) * #magn * #width * @density  
    if (value >= 0.98) ;Limit Correction
        value = 0.98
    endif
endif

  #index = value


default:
  title = "Better Distance Estimator New"
  param power
    caption = "Exponent"
    default = 2.0
    hint = "This should be set to match the exponent of the \
            formula you are using. For Mandelbrot, this is usually 2."
  endparam
  int param distance
    caption = "Distance"
    default = 1
    enum    = "Soft" "Hard"
  endparam
  float param density
    caption = "Density"
    default = 1.0
  endparam
}
Ohh, Tans much! i could not get it done until now. (You have to be a skilled mathematician to get attention i think.) I had my time with the distance coloring too. Here is my variant. The hard one should not need to much correction over rotation. (i translate it from CP, but should work.) ```` mjd_private.ucl:BetterDistanceEstimatorNew(OUTSIDE) { init: complex dz = (1, 0) loop: ; dz = @power * #z^(@power-1) * dz + 1 dz = (dz * #z ^ (@power - 1) * @power) + 0 final: ; #index = (@power*log(cabs(#z)) * cabs(#z) / cabs(dz))^(1/@power) * sqrt(#magn) float value if (@distance == &quot;Soft&quot;) value = (real(@power) * log(cabs(#z)) * cabs(#z) / cabs(dz) * #magn) ^ (1 / real(@power)) value = sqrt(value) * @density else dz = @power * #z * log(cabs(#z)) / dz value = cabs(dz) * #magn * #width * @density if (value &gt;= 0.98) ;Limit Correction value = 0.98 endif endif #index = value default: title = &quot;Better Distance Estimator New&quot; param power caption = &quot;Exponent&quot; default = 2.0 hint = &quot;This should be set to match the exponent of the \ formula you are using. For Mandelbrot, this is usually 2.&quot; endparam int param distance caption = &quot;Distance&quot; default = 1 enum = &quot;Soft&quot; &quot;Hard&quot; endparam float param density caption = &quot;Density&quot; default = 1.0 endparam } ````
 
0
reply

I always try to expand the formulas so i can use it for higher powers. In case you are interested, here some work in progress.
In this case higher powers not work jet, the formula must be made fit for Epicycloid.
But, center is calculated, sign simplified, rotation slowed down, formula combined.

complex center = (1 / @power) ^ (@power / (@power - 1))   ; Center shift for any power

if (@rollBack)

    float r = sqrt(abs(@rot))
    float sig = 1
    if (imag(c) < 0), sig = -sig ,endif
    if (@rot < 0), sig = -sig ,endif

    c = (1 / (c - center)) ^ (1 / @power) + (r * sig)   ; Roll up to Cardioid

endif

c = (1 / c^@power) + center  ; Unroll to Line
I always try to expand the formulas so i can use it for higher powers. In case you are interested, here some work in progress. In this case higher powers not work jet, the formula must be made fit for Epicycloid. But, center is calculated, sign simplified, rotation slowed down, formula combined. complex center = (1 / @power) ^ (@power / (@power - 1)) ; Center shift for any power if (@rollBack) float r = sqrt(abs(@rot)) float sig = 1 if (imag(c) &lt; 0), sig = -sig ,endif if (@rot &lt; 0), sig = -sig ,endif c = (1 / (c - center)) ^ (1 / @power) + (r * sig) ; Roll up to Cardioid endif c = (1 / c^@power) + center ; Unroll to Line
 
0
reply
297
views
9
replies
3
followers
live preview
Enter at least 10 characters.
WARNING: You mentioned %MENTIONS%, but they cannot see this message and will not be notified
Saving...
Saved
All posts under this topic will be deleted ?
Pending draft ... Click to resume editing
Discard draft