frontpage.
newsnewestaskshowjobs

Made with ♥ by @iamnishanth

Open Source @Github

fp.

Claude Opus 4.6 extends LLM pareto frontier

https://michaelshi.me/pareto/
1•mikeshi42•1m ago•0 comments

Brute Force Colors (2022)

https://arnaud-carre.github.io/2022-12-30-amiga-ham/
1•erickhill•3m ago•0 comments

Google Translate apparently vulnerable to prompt injection

https://www.lesswrong.com/posts/tAh2keDNEEHMXvLvz/prompt-injection-in-google-translate-reveals-ba...
1•julkali•4m ago•0 comments

(Bsky thread) "This turns the maintainer into an unwitting vibe coder"

https://bsky.app/profile/fullmoon.id/post/3meadfaulhk2s
1•todsacerdoti•5m ago•0 comments

Software development is undergoing a Renaissance in front of our eyes

https://twitter.com/gdb/status/2019566641491963946
1•tosh•5m ago•0 comments

Can you beat ensloppification? I made a quiz for Wikipedia's Signs of AI Writing

https://tryward.app/aiquiz
1•bennydog224•6m ago•1 comments

Spec-Driven Design with Kiro: Lessons from Seddle

https://medium.com/@dustin_44710/spec-driven-design-with-kiro-lessons-from-seddle-9320ef18a61f
1•nslog•6m ago•0 comments

Agents need good developer experience too

https://modal.com/blog/agents-devex
1•birdculture•7m ago•0 comments

The Dark Factory

https://twitter.com/i/status/2020161285376082326
1•Ozzie_osman•8m ago•0 comments

Free data transfer out to internet when moving out of AWS (2024)

https://aws.amazon.com/blogs/aws/free-data-transfer-out-to-internet-when-moving-out-of-aws/
1•tosh•9m ago•0 comments

Interop 2025: A Year of Convergence

https://webkit.org/blog/17808/interop-2025-review/
1•alwillis•10m ago•0 comments

Prejudice Against Leprosy

https://text.npr.org/g-s1-108321
1•hi41•11m ago•0 comments

Slint: Cross Platform UI Library

https://slint.dev/
1•Palmik•15m ago•0 comments

AI and Education: Generative AI and the Future of Critical Thinking

https://www.youtube.com/watch?v=k7PvscqGD24
1•nyc111•15m ago•0 comments

Maple Mono: Smooth your coding flow

https://font.subf.dev/en/
1•signa11•16m ago•0 comments

Moltbook isn't real but it can still hurt you

https://12gramsofcarbon.com/p/tech-things-moltbook-isnt-real-but
1•theahura•20m ago•0 comments

Take Back the Em Dash–and Your Voice

https://spin.atomicobject.com/take-back-em-dash/
1•ingve•20m ago•0 comments

Show HN: 289x speedup over MLP using Spectral Graphs

https://zenodo.org/login/?next=%2Fme%2Fuploads%3Fq%3D%26f%3Dshared_with_me%25253Afalse%26l%3Dlist...
1•andrespi•21m ago•0 comments

Teaching Mathematics

https://www.karlin.mff.cuni.cz/~spurny/doc/articles/arnold.htm
2•samuel246•24m ago•0 comments

3D Printed Microfluidic Multiplexing [video]

https://www.youtube.com/watch?v=VZ2ZcOzLnGg
2•downboots•24m ago•0 comments

Abstractions Are in the Eye of the Beholder

https://software.rajivprab.com/2019/08/29/abstractions-are-in-the-eye-of-the-beholder/
2•whack•24m ago•0 comments

Show HN: Routed Attention – 75-99% savings by routing between O(N) and O(N²)

https://zenodo.org/records/18518956
1•MikeBee•24m ago•0 comments

We didn't ask for this internet – Ezra Klein show [video]

https://www.youtube.com/shorts/ve02F0gyfjY
1•softwaredoug•25m ago•0 comments

The Real AI Talent War Is for Plumbers and Electricians

https://www.wired.com/story/why-there-arent-enough-electricians-and-plumbers-to-build-ai-data-cen...
2•geox•28m ago•0 comments

Show HN: MimiClaw, OpenClaw(Clawdbot)on $5 Chips

https://github.com/memovai/mimiclaw
1•ssslvky1•28m ago•0 comments

I Maintain My Blog in the Age of Agents

https://www.jerpint.io/blog/2026-02-07-how-i-maintain-my-blog-in-the-age-of-agents/
3•jerpint•28m ago•0 comments

The Fall of the Nerds

https://www.noahpinion.blog/p/the-fall-of-the-nerds
1•otoolep•30m ago•0 comments

Show HN: I'm 15 and built a free tool for reading ancient texts.

https://the-lexicon-project.netlify.app/
5•breadwithjam•33m ago•2 comments

How close is AI to taking my job?

https://epoch.ai/gradient-updates/how-close-is-ai-to-taking-my-job
1•cjbarber•33m ago•0 comments

You are the reason I am not reviewing this PR

https://github.com/NixOS/nixpkgs/pull/479442
2•midzer•35m ago•1 comments
Open in hackernews

Show HN: I was curious about spherical helix, ended up making this visualization

https://visualrambling.space/moving-objects-in-3d/
865•damarberlari•5mo ago
I was wondering how I can arrange objects along a spherical helix path, and read some articles on it.

I ended up learning about parametric equations again, and make this visualization to document what I learned:

https://visualrambling.space/moving-objects-in-3d/

feel free to visit and let me know what you think!

Comments

RugnirViking•5mo ago
It's a pretty basic primer to the subject, but good for kids learning maths. Could do with some callbacks to maths concepts like the circle equation ( x = r cos (t) and y = r sin (t) ).

Possible topics to branch further into would be polar coordinates and linear algebra basics (vectors, transformations, transformations in 3d space). If you the author aren't sure of such topics, I would recommend 3blue1brown yt videos on the matter

Possibly better for that than for programmers (given it doesn't include code or libraries used or anything about actually manipulating 3d objects like vertices, stretching and morphing to achieve the effect shown etc)

srean•5mo ago
These used to be super important in early oceanic navigation. It is easier to maintain a constant bearing throughout the voyage. So that's the plan sailors would try to stick close to. These led to let loxodromic curves or rhumb lines.

https://en.m.wikipedia.org/wiki/Rhumb_line

Mercator maps made it easier to compute what that bearing ought to be.

https://en.m.wikipedia.org/wiki/Mercator_projection

This configuration is a mathematical gift that keeps giving. Look at it side on in a polar projection you get a logarithmic spiral. Look at it side on you get a wave packet. It's mathematics is so interesting that Erdos had to have a go at it [0]

On a meta note, today seems spherical geometry day on HN.

https://news.ycombinator.com/item?id=44956297

https://news.ycombinator.com/item?id=44939456

https://news.ycombinator.com/item?id=44938622

[0] Spiraling the Earth with C. G. J. Jacobi. Paul Erdös

https://pubs.aip.org/aapt/ajp/article-abstract/68/10/888/105...

jacobolus•5mo ago
You inspired me to submit one of my 2022 projects

https://observablehq.com/@jrus/spheredisksample

https://news.ycombinator.com/item?id=44963521

to fit the trend of the day. People may also enjoy

https://observablehq.com/@jrus/sphere-resample

srean•5mo ago
Great to see you. I look forward for your comments on geometry, multivariate calculus and rotations.

Edit: fantastic graphics. You should submit the other one as an HN post too.

egwor•5mo ago
In my early teens I used to try to create something like a equirectangular projection because when drawing it, it looked cool. Obviously I had no idea that it was called this. I was trying to draw reflections of a square window onto a sphere, and then I moved on to trying to cover the sphere in a checkered pattern. This is awesome to see, thank you!
jacobolus•5mo ago
An equirectangular projection just means plotting latitude and longitude in a rectangle.

Do you mean my diagonal grid that I projected back onto the sphere? I'm not sure that has a name.

taco_emoji•5mo ago
Don't forget this post, which spawned a discussion of Rhumb lines etc. in the comments: https://news.ycombinator.com/item?id=44962767
srean•5mo ago
I had missed this one ! Thanks.

It is indeed raining spherical geometry today.

mxfh•5mo ago
Except the helix curve shown in OP is NOT a loxodrome or rhumb line.

It has equal spacing on the surface between lines, a loxodrome can't have that property since by definition it must cross the meridians at the same angle at all times. That means it always gets denser near the poles.

---

Start with the curve:

x = 10 · cos(π·t/2) · sin(0.02·π·t)

y = 10 · sin(π·t/2) · sin(0.02·π·t)

z = 10 · cos(0.02·π·t)

Convert to spherical coordinates (radius R=10):

λ(t) = π/2 · t (longitude)

φ(t) = π/2 - 0.02·π·t (latitude)

Compute derivative d(λ)/d(φ):

d(λ)/dt = π/2

d(φ)/dt = -0.02·π

d(λ)/d(φ) = (π/2)/(-0.02·π) = -25 (constant)

A true rhumb line must satisfy:

d(λ)/d(φ) = tan(α) · sec(φ)

which depends on latitude φ.

Since φ(t) changes, sec(φ) changes, so no fixed α can satisfy this.

Conclusion: the curve is not a rhumb line.

this is how one should look for varying intersection angles:

https://beta.dwitter.net/d/34223

srean•5mo ago
Indeed. It is one of the many well known spherical spirals / seiffert spirals.
cwmoore•5mo ago
To quote the storytelling quality of Erdos's abstract:

"The simple requirement that one should move on the surface of a sphere with constant speed while maintaining a constant angular velocity with respect to a fixed diameter, leads to a path whose cylindrical coordinates turn out to be given by the Jacobian elliptic functions."

patcon•5mo ago
Jeez Erdos. This man was so prolific he was still publishing 4 years after he died :o
srean•5mo ago
Many after he passed
Duanemclemore•5mo ago
This is excellent. I'm always looking for good things to show my students on coordinate systems and geometry, and this joins the list. Thank you for diving down the rabbit hole and bringing this back for everyone.

If you want really great further consideration of creating geometric figures with parametric equations, Joseph Choma's book "Morphing" is an all-timer.

https://www.quercusbooks.co.uk/titles/joseph-choma/morphing/...

damarberlari•5mo ago
oh wow, the book looks nice. thanks for the recommendation!
fleebee•5mo ago
I love this. It's pretty and really easy to digest.
maxbaines•5mo ago
Best thing I have seen on HN in ages. Also interesting for a CNC geek.
ejp•5mo ago
I had a similar thought about 3D printing - particularly extruding mathematically defined shapes in vase mode.

In both of these cases, mathematically generating the points to visit (in gcode) is needed, and we don't care about constant speed - the firmware handles the instruction->motion part.

I am thinking about non-planar printing mostly, but this could also apply to CNC finishing passes.

1970-01-01•5mo ago
That is beautiful animation. This is a great example of a visual lesson that leaves a chalkboard in the dust (ha).
mostlyk•5mo ago
This is super nice to view, could you share how you made it? I want to make something similar for Rotation Matrices
qwertytyyuu•5mo ago
I think 3blue1brown might have an animation library, the same one he uses in his videos that might help with that
megaloblasto•5mo ago
He created a visualization library called Manim and it's great.
jhaile•5mo ago
I was also hoping to see more about how the animations were done here. They look great. I love the shifting camera perspectives.
mikestaas•5mo ago
AnimeJS, and possibly Three.js
fluoridation•5mo ago
For me personally it's simpler to think about it as having an f(theta, r) = r (cos(thetha), sin(theta)), interpreting theta as a compass direction and r as a distance to walk along a great circle. So g(t) = polar_to_R3(f(t k, t l)). Changing the relative sizes of k and l changes the tightness of the helix.
danans•5mo ago
Nifty, but what I'm curious about is how you created the drain/fill effect on the cube.
pimlottc•5mo ago
I was wondering about the “correctness” of the z-axis movement for the spherical helix. You could pick lots of different functions, including simple linear motion (z = c * t). This would obviously affect the thickness and consistency of the “peels”.

The equation used creates a visually appealing result but I’m wondering what a good goal would be in terms of consistency in the distance between the spirals, or evenness in area divided, or something like that.

How was this particular function selected? Was it derived in some way or simply hand-selected to look pleasing?

crdrost•5mo ago
I think this particular function was selected because it happened to be convenient to program and the visual effect was pleasant enough.

The actual "correct" thing to do would probably be to have the point maintain constant speed in 3D space like a real boat sailing on a globe, right? But that's a rather bigger lift:

    const degrees = Math.PI / 180;
    const bearing = 5 * degrees; // or it might be 85 degrees? Not sure off the top of my head
    const k = Math.tan(bearing);
    const v = 0.001 // some velocity, adjust as needed
    const phi = (t) => v*t/Math.sqrt(1 + k*k) // the sqrt is not strictly needed
    const theta = (t) => k*Math.ln(Math.tan(phi(t)/2)) // this is the annoying one haha
with outputs,

    const x = (t) => Math.sin(phi(t)) * Math.cos(theta(t))
    const y = (t) => Math.sin(phi(t)) * Math.sin(theta(t))
    const z = (t) => Math.cos(phi(t))
I doubt that they did the ln(tan(phi/2)) thing though, but it's what you get when you integrate the k d{phi} = sin{phi} d{theta} equation that you have here.
patrickthebold•5mo ago
Just a thought: Make the velocity of the path constant. There should be some way to take a derivative an set it to a constant and solve for z. ( or really reparameterize the curve t' = f(t)) so the velocity is constant.

Actually, now that I think about it, choosing z = c * t is kind of both influencing how the path is parameterized as well as the path carved out on the sphere.

damarberlari•5mo ago
> You could pick lots of different functions, including simple linear motion (z = c * t)

that was also my first intuition when making this, but turned out making the z function linear won't make it a sphere.

to make a sphere, you have to configure it in a way so that it forms a circle with the other axes. In this vis, its the sin(0.02 * πt) and cos(0.02 * πt) part that do this.

someone makes an interactive version here: https://www.desmos.com/3d/t66etxi1y8 (thanks!) so you can try changing the z function for yourself.

chamomeal•5mo ago
Really nice animations! This is the type of thing that was really hard for me to grasp in school. This lays it out so plainly.
nikolayasdf123•5mo ago
quite beautiful
exasperaited•5mo ago
This is very cool, but somewhat confusing to the eye, because you are actually demonstrating the movement of a point along a path, while visualising it with a cube whose orientation doesn't change when it feels like it should.

The point that is moving is in the centre of the cube. But the cube's orientation is fixed in global space.

So the cube's orientation relative to the path of the spiral/helix is not quite the same as its orientation relative to the path of the straight line.

Your mission, should you choose to accept it ;-)

https://en.wikipedia.org/wiki/Frenet–Serret_formulas

Tyr42•5mo ago
Okay, I have some followup questions. Are the points equally spaced? I.e. the cube's |∆p| is constant? I see you scale z by the sin. What happens of you don't?
zamadatix•5mo ago
Without scaling the rate of change of the given curve would not be constant.
hailpixel•5mo ago
I LOVE when people geek out about the most simple mathematical things*, especially discovering the animation power of the trigonometric functions... or any of mathematics underlying modern interactive stuff. It's one thing to know what they do, it's another to understand the power of that tool.

* I wrote a similar article around making "blobs" a while back: https://www.hailpixel.com/articles/generative-art-simple-mat...

damarberlari•5mo ago
hi, whoa that's a nice article! simple and easy to follow.

thanks for sharing! definitely an inspiration, I might use it for next project :D

scotty79•5mo ago
I was expecting linear progression on z and some nasty square root for amplitude of x,y. It's cool that he basically just used another parametric circle drawn on coordinates z and amplitude of x,y oscillations.
dgrin91•5mo ago
Very cool & pretty, but I feel a little let down. There is a huge leap from the basics of 3d plotting & spheres to the crazy pattern you tease and then show at the end. I understand it as someone who kind of knows this stuff already, but I think its way too big of a leap for someone who doesn't have the background.
zamadatix•5mo ago
I think the crazy plot at the end is not intentionally constructed to be exactly that way, just an example of what you can get if you vary the parameters of cosines and sines in parametric equation setups similar to the ones shown earlier (instead of seeking to align them so they wrap a sphere exactly).
markusw•5mo ago
Beautifully done, thank you for sharing. :-)
latexr•5mo ago
> If you like this, please consider following me on Twitter and sharing this with your friends.

I do like this and will share with a couple of friends. But I no longer have a Twitter account and will definitely not rejoin. Would you consider adding an RSS or JSON feed to your website? Or make a Mastodon account, those provide RSS feeds by default.

netdur•5mo ago
Man, that whole ‘please make an RSS or JSON feed for me’ request reads like Richard Stallman emailing himself a webpage to print out later, let them use Twitter or whatever medium they wants
pavel_lishin•5mo ago
But it's not "for me", it's for everyone who'd be interested in getting regular updates from OP.

Twitter is the absolute worst way to get that, even if I had an account.

latexr•5mo ago
That’s a pretty bad faith interpretation. As if a polite suggestion to add a low-effort, universal, unrestricted, and easily automatable alternative would in any way affect what they currently use. The author is asking people to follow them, it benefits them. Letting them know the ways in which people want to do it is a good thing, and it takes a special kind of curmudgeon considerably more obnoxious than Stallman to invent some fault with that.
sfink•5mo ago
Awesome visualizations.

The part that I was expecting to see but didn't: how can you move at a constant speed? For the original purpose of positioning objects along a path, it doesn't matter. But when moving, you can see it's moving much more slowly at the beginning and end (mostly determined by the radius). What if I want it to travel at a constant rate? Or even apply an easing function to the speed?

I'm sure there's some fancy mathematical trick that would just do it. If I were only more comfortable with math... my handwavy sketch would be to compute the speed function by differentiating the formulas to get dx, dy, and dz and passing them through the Pythagorean equation, then reparameterize on a t' variable using the inverse of the speed function? Maybe? I feel like I'm speaking using words I don't understand.

Sharlin•5mo ago
For constant speed you need a so-called “Euclidean parameterization” where the t value is proportional to s, the Euclidean distance traveled (and thus no matter the value of t, if you add some dt it always works out to the same ds). This is super commonly needed when animating motion along all sorts of curves, as you might guess.

Unfortunately, there’s usually no closed-form solution for it, so we have to do it numerically. And for doing that there’s in general no better way than at each t, binary/interpolation search a dt that roughly corresponds to the ds that you want (start with the previous dt, it’s likely a very good approximation).

In practice, you’d do that once and store the results, basically approximating the curve as a polyline of evenly-spaced points– at least assuming that the curve itself isn’t changing over time!

Kennnan•5mo ago
This pattern of stepping with different ds along a path has a lot of applications in control theory. Often we change the ds/dt ratio based on the known acceleration profile of a motor to minimize jerk and reach our destination as fast as possible.

Generally this idea is called motion profiling: https://www.motioncontroltips.com/what-is-a-motion-profile/

chaboud•5mo ago
The instinct to sort of slow t is right, as the governing functions are maintaining angular velocity with respect to t but scaling radius also with respect to t.

It’s sort of like an Archimedean spiral. So, yeah, if you parameterize velocity and make that constant, you’re in better shape. Note that the radius starts at zero, though, so something is going to have to deal with limits.

A simpler path following approximation (e.g., for a game) might be to just give an iterative system path and tangent targets with respect to Z and then provide an iterative constraint on velocity with some sort of basic tweening (e.g., new = a * old + (1 - a) * target). Then just drag the thing along Z, like bead toys for toddlers.

meindnoch•5mo ago
>I'm sure there's some fancy mathematical trick that would just do it. If I were only more comfortable with math... my handwavy sketch would be to compute the speed function by differentiating the formulas to get dx, dy, and dz and passing them through the Pythagorean equation, then reparameterize on a t' variable using the inverse of the speed function? Maybe? I feel like I'm speaking using words I don't understand.

What you're looking for is called arc length parameterization. Basically, you need to compose the curve with the inverse of its arc length function. Aside from a few special curve families, closed-form solutions don't exist.

damarberlari•5mo ago
thanks!

currently the path is expressed as function of (t), and it's the t that progressed at the constant speed.

so the cube will finished one loop at the same duration, and thats why it moves much slowly at the beginning and end, where distance of one loop is smaller.

I have to admit I made it that way because it's simpler to implement:D. Making it move at constant speed require some more works, but others have provided some solutions here so I think I'll try

mystraline•5mo ago
When I first opened it, its basically a bunch of static pages that made absolutely no sense. My first question was 'why is this garbage being #1 on HN?'

Then I realized that, unlike the early web with banners of "best viewed in Netscape navigator", this was an unstated "best viewed in google chrome".

Alas. At least please check and validate if the site works in Firefox, or notify appropriately. Because this demonstrably does not.

rocmcd•5mo ago
I use Firefox (dev edition, v142.0b9) and it works great.
sli•5mo ago
I'm using dev edition v143.0b2 and I'm apparently not seeing what everyone else is seeing, because I'm just seeing the axis tags moving around using some pretty simple math. Clearly something isn't working and I'm missing something, based on the comments here. Regression in Firefox?
Doc-Bok•5mo ago
It works for me in Firefox.
toss1•5mo ago
Worked fine here on Firefox/Win11.
sssilver•5mo ago
Works great on mobile Safari
wpm•5mo ago
Worked fine for me on desktop Safari.
wigster•5mo ago
works on firefox macos
madhato•5mo ago
Worked fine for me using Firefox 142 on Linux. Did you have any errors in the console?
hotsalad•5mo ago
For me, it doesn't work entirely in Librewolf 142 (shows the text, and some tags moving around an otherwise black screen), but does work in Firefox Nightly.
alias_neo•5mo ago
Worked perfectly for me on Firefox 142.0 on Arch Linux.
aacid•5mo ago
Really love this project, I only have small little UX nitpick: as lefthanded person it is quite cumbersome to tap right side of screen. Go to solution is to navigate using swiping which is ambidexterous.
ghostly_s•5mo ago
As a left-handed person I have no problem holding the phone in my right hand when I need to use UI on that side of the screen. Though I do prefer phones on the small side.
meken•5mo ago
This is why I love small phones - I’m able to reach and tap with left thumb quite easily on my iPhone SE.
SKILNER•5mo ago
That's an excellent job of teaching - thank you!
erikerikson•5mo ago
Thanks. My useful feedback is that navigation violated my expectations. I was in mobile FWIW. I didn't know what to do so I started to scroll. My touch to the screen kicked into the next pane so I'm like "oh, okay". I happened to touch the right side so I thought that advanced it and so when I later clicked an extra time unintentionally, I tried to click the left side to go back (note that people who read right to left it top to bottom may have different intuitions [or be used to an insensitive web]). Unfortunately that just skipped another screen so that I missed two in a row. Not fatal because I kept going but disappointing and micro-sad. I think some subtle guidance could have removed the ambiguity and helped me focus and engage better.
ghostly_s•5mo ago
There are instructions on the first slide. I think adding a secondary swipe mechanic would be nice tho (although I prefer the tap), as that's how these "card stack" interfaces are usually navigated in social media apps.
erikerikson•5mo ago
Oh, you're right. Small and at the bottom. I guess I tried to scroll before my eyes got there. Thanks for pointing out my error.
damarberlari•5mo ago
ah, yes there is an instruction at the bottom, but probably its too small.

thanks for the feedback!

ezconnect•5mo ago
The solar system spiraling through the universe.
tantalor•5mo ago
> Together, these functions create a spherical helix... That's all!

This strikes me as backwards reasoning.

You are showing "these functions" -> spherical helix

But I actually want spherical helix -> "these functions"

1. What if I want to make some other shape? I'm lost.

2. I have learned nothing about the spherical helix.

ShahoG•5mo ago
This was amazing! I also checked the understanding neural network. Looking forward to the next part in that one. Keep up the good work!
jtbayly•5mo ago
I believe there is a typo here:

y = 10 * sin(πt/2) * sin(0.02 * πt)

On the previous two slides the end is sin(0.2 * πt)

dwayne_dibley•5mo ago
Well this is lovely. Well done.
stephenlf•5mo ago
I love the slight aliasing on the visuals (iOS Safari). It makes it obvious that it’s rendered on the fly.
nedsma•5mo ago
Brilliant, I learned something today.
mustaphah•5mo ago
I can't tell why, but I'm getting terrible performance on Linux/Brave. The CPU spikes immediately on visit. I'm on a powerful machine (32 GiB RAM, Intel i9 w/ 24 cores).
jeffbee•5mo ago
> I can't tell why

Let's find out where this sentence goes!

> Linux

Would look into that.

> Brave.

Definitely would look into that.

> 32 GiB RAM, Intel i9 w/ 24 cores

This part is not relevant

mustaphah•5mo ago
You're just jealous of my 32 GiB.
jeffbee•5mo ago
Crying in Mac mini voice
fragmede•5mo ago
How is that not relevant?
jeffbee•5mo ago
Because any non-broken combination of browser and software platform can run this on any PC made this century. It runs fine on my terrible Atom Chromebook, even.
Anon_troll•5mo ago
I encountered similar trouble with both Firefox and Chrome on Ubuntu.

Based on a quick Firefox performance report on the minified source code, most of the time seems to be spent in functionality looking like frame handling. There are some signs of time calculations.

One educated guess would be that something in frame time calculations goes off, possibly due to restricted time resolution to prevent timing related fingerprinting. This would cause next frame computation to start immediately instead of after the intended timeout.

mustaphah•5mo ago
Frankly, it seems to work fine on Firefox. It's a Brave issue for me.
thopkinson•5mo ago
This is fantastic. What a terrific combination of the creative presentation and the clear exposition of information. You've hit on a very nice aesthetic and a stunningly clear articulation of the underlying mechanics.
lucho_mzmz•5mo ago
Cool! My first instinct was to scroll. I suggest you treat the scroll down as a signal to move 1 slide further
lucho_mzmz•5mo ago
Cool! My first instinct was to scroll. I suggest you use the scroll down as a signal to move 1 slide further
meken•5mo ago
This was delightful - thank you!
reeece•5mo ago
The animations are so fluid!

I very recently was looking to generate some complex shapes, and stumbled onto the complex problem of "disperse N points on sphere" and all its nuances.

There was a really cool / simple algorithm that was mentioned called the fibonacci-sphere that also generates a spiral around a sphere, but for the point dispersal. Here's a paper [1] on it that talks more about it.

[1] - https://arxiv.org/pdf/0912.4540

metalman•5mo ago
it's impressive enough to crash my browser (twise) before I got to see it the full digital resource conflict jam and judder!
ramathornn•5mo ago
This is so cool! Thanks for sharing, stuff like this is why I love HN.
taherchhabra•5mo ago
so beautiful. thank you for this. I am trying to develop intuition for sine cosine etc. and it did fire some neurons in my brain not sure i can put that into words
MarcelOlsz•5mo ago
Wish the bundle.js wasn't minified so I can look at the code and see what's going on!
adammarples•5mo ago
Very distracting to try and read text in the middle of a constantly spinning visualisation
dcanelhas•5mo ago
https://www.johndcook.com/blog/2023/08/12/fibonacci-lattice/

If you want a spiral that covers the sphere with evenly spaced samples, consider this approach.

gowld•5mo ago
And the Matt Parker Stand-up Maths video: "Golf balls: How many holes in one?" https://www.youtube.com/watch?v=dNTnk1VFoJY
gabeyaw•5mo ago
This reminds me of how the spins in MRI are manipulated in order to acquire the signal. Tracking the tips of the spins traces out similar looking paths. https://m.youtube.com/watch?v=vapJRr6gAds&t=2786s
NooZ•5mo ago
I never tought this would be interesting but it is VERY much.
alias_neo•5mo ago
Really nice visualisation.

Does anyone know of any tooling I could use to do some plotting like this in 3D space even a fraction as nice looking as OPs? I'm not a web dev but I am a dev, but would prefer something high enough level that I can focus on the "what" (to plot) rather than the "how".

Theodores•5mo ago
In the olden 8-bit days, we would have to do this in BASIC or assembler with a 3D library that we would have to write ourselves. Then we would run out of memory.

Later on - about a quarter of a century ago - we had VRML which enables anyone to just focus on the what rather than the how. But VRML always needed a plugin to download, which was no fun at all in the dial-up days. We almost had a 3D web, but no, it ended up 2D.

I digress. However, if you want 3D plots without having to reinvent the wheel, three.js is fit for purpose, with the right CodePen example to get you started.

alias_neo•5mo ago
> In the olden 8-bit days

I hear you.

My first real experience with drawing anything was with Postscript, but then I did my fair share of blitting, and a bit of OpenGL. These days I'm just looking to visualise some data in a nice looking way with minimal effort.

> if you want 3D plots without having to reinvent the wheel, three.js is fit for purpose, with the right CodePen example

Amazing, thanks for the tips.

thefringthing•5mo ago
Grammar problem: "In 3D space, we position objects by setting its coordinates" should read either "their coordinates" or "an object".
willdelorm•5mo ago
I am about to start my computer science degree, so this visualization got me really excited to dive into the mathematics of it all. I love to see these kind of animations, but the math behind them sends my brain spinning! Very cool to see it broken down in a digestible way like this.
mayoff•5mo ago
You can play with the equations on 3D Desmos here: https://www.desmos.com/3d/t66etxi1y8

Interesting to note that the parametric equations of the spiral are linear in spherical coordinates. https://en.wikipedia.org/wiki/List_of_common_coordinate_tran...

damarberlari•5mo ago
this is nice, thanks!
pavel_lishin•5mo ago
I've recently gotten interested in p5js, which is a fun and easy way to explore this kind of stuff; if anyone here is currently thinking (like I am) that you want to try this out yourself, I'd give it a try: https://p5js.org/tutorials/setting-up-your-environment/
BlitzCloud•5mo ago
This is awesome, it was easier to understand that what my uny theacher tried to explain.
Gud•5mo ago
Love it
coreyp_1•5mo ago
The content is good, but the weird dither effect is giving me a horrible headache! I'm glad you created it (it's always good to see someone bring an idea to fruition!), and I hope that you continue to create cool things. But please, please, please turn off whatever effect you're using.
grimgrin•5mo ago
the dithering is lovely and the OP better not touch it. they can give you a toggle though :P
addaon•5mo ago
> …which we know isn't actually chaotic. It's just a path defined by mathematical functions.

I don't know what function is being presented, so I can't speak to whether it demonstrates chaotic behavior -- but the whole /point/ of chaos is that it's an emergent property of deterministic mathematical functions. Perhaps the author meant "random" or "non-deterministic" rather than "chaotic"?

skalidindi3•5mo ago
^^^ This is an extremely underrated nitpick.

I am guessing that the HN audience would be / should be interested in that distinction. Mathematically speaking, chaos is an extreme sensitivity to initial conditions, and is very much still in line with deterministic systems. The resulting output, while seemingly random (since there is no easily identifiable pattern), is mathematically and conceptually different from actual randomness.

altruios•5mo ago
'actual' or 'true' randomness is a rabbit hole.

https://en.wikipedia.org/wiki/Randomness

It really depends on the exact definition of what you are quantifying 'random' to be.

There is no proof (in the mathematical sense) of real randomness.

lotyrin•5mo ago
I use "Random" to mean chaotic (extreme sensitivity to initial conditions) but with unknown (or unknowable) initial conditions.
dcanelhas•5mo ago
I think that makes sense and I can tell that you understand the distinction. Formally I believe they're different concepts and think it may cause confusion in some cases to use them interchangeably.

The chaotic nature of a system is one thing.

Our lack of knowledge of the governing laws, initial conditions, feasibility of simulation forcing us to use the mathematical tools of probability (i.e. randomness) to describe our uncertainty about said system is another thing.

The reason why it matters is that a statement like "a double inverted pendulum behaves randomly" is just wrong as it would imply that you couldn't even do a simulation of one in theory without throwing some dice.

However, it is totally uncontroversial that if someone gave you a measured initial position and velocity of one with 'really good' precision and asked you to predict its state 5 seconds forward you would likely have a big smeared-out probability density function to deal with.

TheOtherHobbes•5mo ago
There are a number of sophisticated tests for randomness. You can't prove absolute randomness in any Platonic sense, but you can certainly assess a source for different properties that are useful in applications that require randomness.

In this example the path is neither chaotic (in the formal sense) nor random, because a Fourier transform would identify the harmonic components.

latexr•5mo ago
> the whole /point/ of chaos is that it's an emergent property of deterministic mathematical functions.

I believe you. But the colloquial definition (I’m looking at a dictionary right now) is “complete disorder and confusion”; “a state of things in which chance is supreme”; “the inherent unpredictability in the behavior of a complex natural system”. That path fits that apparent definition. The post is written in a way that a relative layman would understand, so it makes sense to speak/write in a way non-mathematicians would expect.

addaon•5mo ago
> That path fits that apparent definition.

Then saying it "isn't actually chaotic" is mis-aligned with the layman's understanding, and the disagreement is not explained (either by explaining a more technical definition, or otherwise).

I continue to think that substituting "non-deterministic" or "random" would be more both understandable to the layman, and more correct to the advanced reader.

dcanelhas•5mo ago
I just did a mental substitution for the word "stochastic" and moved on, since it wasn't the main point of the article. But you are correct. Computing the future states of a chaotic system, given the same initial conditions, will produce the same results every time but change the initial conditions ever so slightly and you have no guarante where you will end up next (unless you picked a state from a previous simulation, that is... But that's cheating;) )
fsckboy•5mo ago
when it gets past the "intro" slides and into the A-B-C explanation, slide 11 says "A helix is a shape that loops around and around, like a spring." Unfortunately, what is shown is not a helix nor a normal spring, it's just yet another spherical helix progression.

also, the progress dots at the bottom should be toc nav buttons, single stepping backward to find the slide above was torture.

and the derivation of a circle from two sines and a sphere from three, to me should really be separated out as a "pre req" presentation. this thought goes along with the above "hey, where's my helix" thought

rashidae•5mo ago
Wow! You did something amazing! The first few interactions, I felt as if I was actually spinning a wheel. Great job, bravo!
horacemorace•5mo ago
Funny I remember blindly stumbling down OP’s same path at 13 using Quickbasic.

/old

shawa_a_a•5mo ago
Surprised to not see Acko.net mentioned in comments already - he uses similar aids in one of his blog posts to break down complex numbers and ultimately fractals.

Likely right up your street!

https://acko.net/blog/how-to-fold-a-julia-fractal/

natewww•5mo ago
thanks for sharing, really interesting
phyzome•5mo ago
It seems like it might be cool but between the background animation and the resource intensiveness I'm having trouble actually reading it. Is there a mostly-text version somewhere?
Keyframe•5mo ago
Neat! I was curious as well after reading it and here's a quick parametric visualizer to play with what was described in the text (thanks, Claude!): https://codepen.io/CaptainKeyframe/pen/zxvWVNo
damarberlari•5mo ago
wow, that's nice. Thanks!
tianyu1718•5mo ago
Before I came here, I didn't know there were people using web pages to demonstrate such cool things.
haritha-j•5mo ago
this is so pretty. Have you done any write-ups on how to create this (or any of the other visualisations on your page). I would love to learn more.
ForHackernews•5mo ago
If you like this, you will probably enjoy https://www.shadertoy.com/ and https://thebookofshaders.com/
p00dles•5mo ago
I applaud anybody who makes visualizations of difficult to grasp concepts - so, thank you very much.

As a visual (spatial) learner, I often wonder how my math/science education could have been improved with learning tools such as these.