return to table of content

Pluckable Strings

traviswt
17 replies
23h25m

Really wish this wasn't so... nsfw. My kid would love it, but there's no way in the world I'm sending him this link.

cdchn
12 replies
22h54m

Whats nsfw about it?

FpUser
7 replies
22h42m

Nothing I think. But I can see why some people will find the opposite.

2024throwaway
6 replies
22h24m

Why? I honestly have no idea why anyone could consider this NSFW. I will absolutely be showing it to my kids.

cdchn
5 replies
22h13m

The sticky lips may illicit impure thoughts.

Tao3300
2 replies
20h59m

That says more about the beholder.

cdchn
0 replies
18h48m

Let me rephrase.

Sticky lips ARE eliciting impure thoughts.

FpUser
0 replies
20h29m

Yup

hombre_fatal
0 replies
22h4m

Especially in his child, apparently. What an odd idea.

2024throwaway
0 replies
22h4m

Scandalous!

lIl-IIIl
2 replies
22h10m

I think the poster referred to other parts of the adult swim website. It's not NSFW, but more like M+ TV rating.

lisper
0 replies
21h22m

The name is a bit of a clue.

cdchn
0 replies
21h33m

Yeah that just occurred to me too when someone posted a free-from-adult-swim link to the same thing.

traviswt
0 replies
19h11m

Scroll down.

smusamashah
0 replies
21h49m

I let my toddler play with it for a while on my phone, he didn't enjoy it very much.

traviswt
0 replies
19h8m

This is fantastic, and with the vowel has another dimension. Love it, thank you!

recursive
1 replies
21h10m

Doesn't seem like a gag to me. I find this one to be a lot more musically interesting. The "pluckable" demo makes it kind of hard to do anything musically interesting based on the constraints of the screen-based UI.

The blob one harmonizes in a very interesting way. I would love to know the algorithm. Maybe even enough to pull apart the source code or reverse engineer it.

earslap
0 replies
21h2m

IIRC the progressions are generated by a small neural network trained on Bach chorales.

FpUser
0 replies
22h45m

OMG, this is so insanely cool. Love it.

aidenn0
13 replies
1d1h

Really cool that plucking the strings near the edges gives a different timbre than plucking in the middle.

madcaptenor
10 replies
1d

Oh hey, it does. But why? (Seems like the same thing is true on actual physical strings.)

seanhunter
4 replies
1d

The way strings resonate means the tone you hear contains the fundamental tone and a number of higher harmonics of that tone. Depending on where (and how) you play the string you can emphasise the harmonics more or the fundamental tone more.

Here for example is a piece made up largely of the harmonics (Portrait of Tracy Jaco Pastorius) https://www.youtube.com/watch?v=nsZ_1mPOuyk That's an electric bass and the bell-like sounds are harmonics. Basically he's just lightly touching the string in specific places to suppress the fundamental tone so you just hear the harmonics.

Whereas here (Stir it up - Bob Marley and the Wailers) https://www.youtube.com/watch?v=1hwL3S3Gtzs when the bass comes in, the player is holding his hand near the bridge (back of the strings) with the side of the palm resting on the strings to suppress all the harmonics so you only get the fundamental tone and it has this sort of muffled quality (because a lot of the brightness comes from harmonics).

tetha
1 replies
21h37m

the player is holding his hand near the bridge (back of the strings) with the side of the palm resting on the strings to suppress all the harmonics so you only get the fundamental tone and it has this sort of muffled quality (because a lot of the brightness comes from harmonics).

Palm muting is one big technique to the more aggressive and chunkier metal sounds[1].

Even if you take out the music theory - or blatant disregard for - except kinda not, it's complicated, the different way you can create sounds with an electric guitar[2] in weird ways is quite amazing.

1: https://www.youtube.com/watch?v=yg4tKoiGoyM

2: https://www.youtube.com/watch?v=H4ax35i6aIY

nicklecompte
3 replies
1d

It's not just where you pluck the string: most electric guitars have a "neck" pickup and a "bridge" pickup (sometimes a third in the middle). The neck pickup is closer to the middle of the string, and the bridge pickup is close to the end of the string. Regardless of where you pluck, the bridge pickup has a significantly more prominent high-end, to the point of being a bit shrill when played in isolation. Typically rock guitarists play rhythm with the neck pickup so they don't overpower the vocalist, then lead with the bridge pickup so they cut through the mix without needing to amp the volume too loudly.

Why is this the case? It is funny that my guitarist's intuition seems very clear about it - "the string is tougher and clickier at the bridge compared to the neck, of course the tone is more shrill" - but in terms of actual analytical evidence I just have to say "something something Fourier coefficients" :) Refining the physical intuition a bit: I believe the boundary at the end of the string dampens lower-frequency (i.e. lower-energy) vibrations faster than higher-frequency vibrations, so the lower harmonics die off more quickly than the higher "nasal" harmonics.

mrob
2 replies
23h6m

Isn't it just the geometry of the guitar constraining the ends of the string to have zero amplitude? The fundamental has peak amplitude only at the center of the vibrating part of the string. Higher harmonics have peaks in amplitude at multiple places along the string, and the higher the harmonic the closer one of those maxima is to the bridge.

nicklecompte
0 replies
21h33m

The fundamental result of Fourier analysis is that we are saying the same thing :) Though I should have clarified that the kinetic energy is zero at the "boundary" (ie bridge).

IMO which answer you prefer depends on perspective:

- if you assume a wave can be broken down into sinusoidal overtones then your geometric approach is much more immediate and intuitive: sinusoidal overtones => higher overtones clearly have more kinetic energy near the boundary, just draw a picture.

- if you assume that higher-pitched overtones have more kinetic energy then the physics approach explains why they are sinusoidal. Not the specific shape unless you do the math, but the "gist" of the slope. If the overtones were more like square waves, with no real difference in shape between frequencies beyond the length of the rectangle, then the pickup position wouldn't matter. But they can't be, the overtones have to be more "trapezoidal." And in particular, the lower overtones must have a more gradual slope than the higher overtones.

The geometric approach makes a big (but correct) physical assumption for an easy analytical argument; the physical approach goes the other way, only depending on Newton's laws + a lot of elbow grease.

PaulHoule
0 replies
1d

See https://phys.libretexts.org/Bookshelves/Waves_and_Acoustics/...

Touching the string at different points will excite different vibrational modes. Notably if you pluck in the exact center you activate none of the even-numbered nodes, if you pluck around the 1/3 point that's optimal for activating the second harmonic, etc. You can never not activate the fundamental mode touching it in one spot but you activate it less if you get close to the edge.

plasticeagle
0 replies
20h33m

It does, and very cleverly too. The '?' button explains what's going on - he just takes the fourier analysis of the shape of the string when it's released, and plays tones from that.

pindab0ter
0 replies
3h14m

Just like on a real string instrument! I was wondering if they implemented this, and they have! Colour me impressed!

isoprophlex
11 replies
1d1h

It's shockingly easy to make it sound good! Someone who understands music please explain to me why this works so well, I'm amazed!

groby_b
2 replies
1d1h

As others said - they're chords. And not just any chords, but chords we know sound great together. (If you haven't seen the 'Pachelbel Rant' yet, you should, it's an entire comedy bit based on the fact that these chords are fundamental to music: https://www.youtube.com/watch?v=uxC1fPE1QEE)

If you click on the little notes in the bottom right, you can pick other sets of chords, which give a different "vibe". (Me, I'm partial to the Andalusian ones)

That's why common advice to people starting the guitar is "Three chords, you can play anything. Four, you control the mood. Five, you're a god among men"

madcaptenor
1 replies
1d

Pachelbel is slightly more complicated than the default here, five chords instead of four (adding iii - F#m in the key of D that he used, or Em in the key of C which is the key that this defaults to). So I guess that makes Pachelbel a god among men.

jzemeocala
0 replies
1d

Actually....Pachelbel used a major III

fallingsquirrel
2 replies
1d1h

The four groups of strings make up four chords. Going clockwise, they are C, Am, F, G. This is a common chord progression[1] in pop music. It became popular because the chords sound good together.

https://en.wikipedia.org/wiki/%2750s_progression

aidenn0
0 replies
1d1h

I should note that this is the same 4 chords as the '50s progression, but a different ordering (I V vi IV vs I vi IV V). One is associated with more recent pop/punk music and the others is more associated with doo-wop.

welfare
1 replies
1d1h

They are all chords (C, F, G, Am).

C/Am, F, G are adjacent in the circle of fifths so they will all play nice in a progression.

metaxy2
0 replies
1d

To flesh this out, the root notes of C and A minor are not that close in the circle of fifths, but the chords sound similar because they share 2 notes (C is spelled C, E, G, and A minor is spelled A, C, E). A common device in major keys is to take a part played over the "1" chord (C in this case) and play it again, or some close variation, over the chord 2 steps down (A minor in this case) to get a "kind of the same, but sadder" version of the same part.

postepowanieadm
0 replies
1d1h

Even when making my own string it still sounds good. I didn't known I'm that gifted!

fuzzfactor
0 replies
5h39m

There is an acoustic version, you can tune it however you like, and choose from all kinds of chords, but once you chose a chord it has to be tuned precisely to that set of notes or it would be "out of tune".

Each course of strings on the webpage somewhat behaves and sounds like an "ovikannel" when you strum it manually.

Here's one that was found hanging on a wall but they were normally attached to an entrance door so the wooden balls would swing against the strings when the door was opened, and play the chime:

https://www.reddit.com/r/finnish/comments/dvd125/my_finnish_...

One of the commenters was quite curious as to what it would sound like. Well about like this.

dsego
0 replies
1d1h

The notes assigned to strings are chosen to make up chords (harmony).

adrianmonk
10 replies
1d

FYI, in Chrome on Linux, there's a glitchy crackling noise. Maybe a buffer under run or something. It happens a lot more often if you strum lots of strings quickly.

It also happens in Firefox but a lot less.

wayoverthecloud
0 replies
23h38m

Chrome on Android too

plasticeagle
0 replies
21h31m

Arc on MacOS too.

petrichorko
0 replies
22h57m

Yes, modifying buffer_size in audio_shader.js to 4096 completely fixes this issue on Windows (chrome).

moffkalast
0 replies
1d

Chrome on Windows as well.

l3x4ur1n
0 replies
1d

Brave on Android also

ikari_pl
0 replies
23h55m

Firefox on Android is fine

elihu
0 replies
22h3m

Can confirm on Chromium/Linux.

chaosprint
0 replies
10h12m

I also have serious popping in chrome on my mac.

This shouldn't happen.

The main reason is the use of createScriptProcessor.

This should be replaced with AudioWorklet. Use WASM + SharedArraybuffer for calculation.

The visual of picking the strings is great, I spent a lot of time on it, I believe the vote is also a recognition of this.

Here is a similar idea (karplus) implemented with Rust + WASM, which is much better in terms of audio quality:

https://jackschaedler.github.io/karplus-stress-tester/

I also wrote a simple api to use Rust wasm audio here:

https://glicol.js.org/

If you are interested in doing some use cases, leave a message. I am actively maintaining it recently.

TazeTSchnitzel
0 replies
23h54m

This can happen a lot with web audio stuff like this, it's the browser struggling to keep up.

SimDeBeau
0 replies
4h8m

No sound on firefox on mac or ipad, and glitchy sound on safari on mac

protosam
5 replies
1d1h

Isn’t working on iOS 17.4, iPhone 14. Both in Safari and the App Store download.

Edit: yes I’d pay $2 to play with this. lol

jpcfl
2 replies
1d1h

You need to take your phone off silent.

protosam
0 replies
15h49m

Well, this fixed it. I bet there is a lot of confusion for the people reporting it just works, while their phone is on silent. Seems to work on silent if you have headphones on.

cush
0 replies
1d

Yeah I thought it was broken on iOS too, then flipped the silent switch and it worked.

isolli
0 replies
7h26m

Definitely getting it for my kids!

CrazyStat
0 replies
1d1h

Works for me on iOS 17.4.1, iPhone 15 Pro.

thebeardisred
4 replies
1d1h

Interesting idea.

I went to share it with some musician friends of mine, but first wanted to give them a TL;DR.

I tried to copy info out of the "?" dialog so that I didn't have to re-type the details but the page blocked the operation. That was enough for me to pass. I don't have time to do extra work to explain someone else's project.

kevmo314
1 replies
1d1h

This seems like a case where a more generous take would be productive. The page itself is a tool that intercepts drags, it seems like an oversight, not intentional, that it also intercepts drags on the help page.

thebeardisred
0 replies
23h29m

I totally agree. Many folks overlook the UX decisions they make when sharing a project. That's why (in the spirit of HN) I began with a compliment and provided information as to why I made the choice.

While I can cop to the fact that some may interpret my comment as "Please don't complain about tangential annoyances—e.g. article or website formats, name collisions, or back-button breakage. They're too common to be interesting." it seems there is an equal and opposite lack of consideration around "Please respond to the strongest plausible interpretation of what someone says, not a weaker one that's easier to criticize. Assume good faith. "

gnrlst
0 replies
1d1h

"pluckable strings". Don't really need anything more exhaustive than that. The discovery process is part of the fun.

blorenz
0 replies
21h8m

Here's the text extracted from a screenshot of the ? provided to ChatGPT so you don't have to do extra work.

Pluck by Murat

A math-based string simulator.

Download on Apple App Store for $1.99 [Image of Apple App Store download button]

- It's fun to have on iPad with multitouch, especially for kids (even 1 year olds). - Support this project

Both the audio and visuals are generated using the same math, rendered at different speeds so the eye can see.

No tricks or audio files are used: everything is calculated from raw sine waves, with a theory of how energy is released in a pluck. - The vibrations are modeled based on how far down the string you pluck from. - The velocity of midi notes are mapped to both pluck position, as well as pluck strength.

This YouTube video of a slow motion string pluck proves that our simulated result is very close to reality. [Embedded YouTube video of slow motion pluck]

Technical details: - Each string is simulated with 12 overtones (integer multiples of the note frequency) - To calculate amplitude of each overtone, we take the Fourier transform of the plucked string at the time the pick is released - Higher frequency overtones decay faster than lower frequency overtones - 72 strings x 12 overtones x 44,100 samples per second = 52,920,000 calculations per second - Audio buffer of 1024 samples are sent to the GPU to compute in parallel on each tick

There are several directions I can take this project from here: 1. Turn it into an interactive educational tool to teach physics of sound, timbre & music. 2. Turn it into a music learning tool for kids where songs are pre-made as chords that the user can pluck to learn rhythm and feel. 3. Turn it into an interactive art installation 4. Turn it into a game where i.e. a bouncing ball plucks the strings & you try to match the melody

If you are interested in any of the above, please get in touch at murat@ayfer.net or @moyfer.

slushy-chivalry
4 replies
1d

I did not look at the source code yet, but is this some sorta physics modeling problem? Treat the strings as a a bunch of interconnected balls, then apply the force at point, compute other forces, interpolate a curve through the new state, then compute frequencies based on where the string was plucked? this is pretty cool

packetlost
2 replies
1d

My guess is the strings are not modeled as balls balls as continuous lines with a set tension oscillating based on their length and thickness. It's presumably a bunch of trigonometry, but not the most insane modeling problem I've seen. Very cool none the less

fedix
1 replies
23h48m

What's the most insane one ?

Rastonbury
0 replies
22h23m

The question mark top left kind explains

scop
3 replies
23h54m

It is great that the author included some known pieces for you to "watch" (click the music icon on the bottom right). Of course one first goes to Bach to test the mettle. While "watching" BWV 578 one thing I immediately noticed was how the rhythm of the counterpoint stood out to me in a new way. I have seen many visualizers (the great https://www.youtube.com/user/smalin/videos deserves mention), but I have found most to have some sort of constant object moving around to visualization the tones (i.e. a ball moving up and down). In this case, there is no "moving object" that we follow and we are instead left with the tones in isolation. I greatly enjoyed seeing how this increased my appreciation of Bach's rhythmic counterpoint as I could see when multiple strings were plucked at the same time with the clear purple coloring. Amazing work!

thrtythreeforty
0 replies
20h55m

Also love that MIDI velocity is mapped to pluck position, so higher velocity notes are brighter. This is a beautiful representation of physical modeling.

tgv
0 replies
11h19m

What I found weird is that there's only one guitar piece in the list: Asturias. The rest is keyboard music. And unfortunately, that piece shows weaknesses in the system. Notes get cut off, the rhythm is wrong, and there was one very loud buzzing sound, which suggests the buffer can't be filled fast enough.

hombre_fatal
0 replies
9h37m

Man, I didn't even notice the icons in the bottom corners. I thought it was just a quick toy on first pass which is a shame because loading existing songs is really cool.

I wonder how many other people close the tab without noticing the buttons like I did.

XCSme
3 replies
4h9m

Nice demo, but for me, plucking the string gives a lot of static noise/crumbling sounds. Anyone else having this issue?

chaosprint
0 replies
3h48m

It will happen to everyone due to use of createScriptProcessor.

This should be replaced with AudioWorklet. Use WASM + SharedArraybuffer for calculation.

Here is a similar idea (karplus) implemented with Rust + WASM, which is much better in terms of audio quality:

https://jackschaedler.github.io/karplus-stress-tester/

XCSme
0 replies
3h59m

I'm on Windows 11, Brave browser. Using Sound BlasterX G6 DAC.

Liskni_si
0 replies
4h1m

yes, me. Chrome 125, Linux x86_64, pipewire.

tambourine_man
2 replies
1d1h

Make sure your phone isn’t on mute. On iPhone, the mute button. I was raising the volume to no avail.

Edit: I don’t know why I’m being downvoted, the mute button is very unintuitive. YouTube will play on a web page with mute on, but this page won’t.

ryandrake
0 replies
20h16m

You're not wrong. To this day I have no idea what my phone's mute button actually mutes and what it lets through.

psadri
0 replies
4h32m

I had the same issue. My phone is permanently muted so I forgot to even check that option.

Probably worth the app/os to give you a notice if you fiddle with the volume while muted.

_spduchamp
2 replies
16h19m

Plucking strings is usually synthesized using Karplus-Strong synthesis which is a very short delay line loop with a low pass filter. The delay gets excited with a short burst of noise. The length of the delay line tunes the string.

Karplus-Strong can be extended in ways to simulate different types of plucking, acoustic pickup at bridge, or electric pickup at any point along tbe string, and plucked at any point along the string. Body resonance can be simulated etc. It's a pretty fun synth technique to play with. Amazing to take beyond simulating conventional instruments.

thrtythreeforty
1 replies
13h59m

Karplus Strong sounds kind of bad though, if your goal is accurate sounds of instruments. The reason it works at all is that the noise generates the initial high harmonics of a pluck, then a low-pass simulates the frequency-dependent decay of those harmonics.

But this is very primitive compared to a massive body of research on better simulation. The delay line works great though, that part hasn't changed.

cp3io
0 replies
4h58m

The algorithm was discovered in 1983, and for how computationally cheap it is, I'd say it's pretty convincing. Waveguide synthesis is a generalization of the same idea, often with more realistic results.

Variations on Karplus-Strong synthesis can yield some pretty wacky, dry and plucky types of sounds. In the original paper, the authors propose a variant of the algorithm which involves randomly alternating the sign (+/-) of every sample in the feedback loop, which creates a lot more atonal information in the signal. There’s also a variation floating around which uses an allpass filter in the feedback loop to introduce inharmonicity in the signal, see for example https://www.youtube.com/watch?v=SpC3t1EVF_Q.

themaninthedark
1 replies
21h46m

I remember haring about someone creating a musical software model that was supposed to allow you to do things that you normally couldn't do i.e. pluck or strum a cymbal.

I tried to find it but never have.

Does anyone else know what it is?

LegitShady
0 replies
20h53m

physical modelling synthesis has been around since the 70s. Some instruments are really complicated and require a bunch of FM oscillators to nicely replicate some physical sounds - things like cymbals and other metallic crashes especially.

ks2048
1 replies
22h27m

It would be nice if he or she described the algorithm in more detail. A common and simple string-synthesis method is called Karplus-Strong, but this sounds a bit better.

elihu
0 replies
22h0m

In case you didn't see it, there's a little bit of detail given if you click the question mark in the upper left.

crawsome
1 replies
1d1h

I'm going to pick this nit, but are they pluckable or strummable? Sounds more like strumming.

QuercusMax
0 replies
1d

If you pluck one of the sets of strings, it's like strumming. But you can pluck them individually, which is definitely NOT strumming.

chaosprint
1 replies
19h45m

amazing work!

However, I must point out that if tonejs is used here, audio will quickly become a bottleneck or even memory leak.

It reminds me of a Karplus Strong project written in rust that I saw before. This project is of course visually minimal, but demonstrates the use of rust + wasm audio.

https://jackschaedler.github.io/karplus-stress-tester/

I wrote a simple api to use Rust wasm audio here:

https://glicol.js.org/

If you are interested in doing some use cases, leave a message. I am actively maintaining it recently.

chaosprint
0 replies
10h4m

Correction:

The cause of the popping glitches is createScriptProcessor

wantsanagent
0 replies
21h32m

Very pleasant, thanks!

vjandrea
0 replies
1d

Very cool project, I love the drawing function, can bring to interesting ideas. Unfortunately, some songs are broken, MIDI file 404. The code tries to parse the empty response, instead of escaping early.

thimkerbell
0 replies
1d

If you have a sense of the song and it's not to your liking, don't be too pluckable.

swiftiepro
0 replies
6h50m

Very interesting

postepowanieadm
0 replies
1d1h

That's seriously awesome!

phgn
0 replies
23h57m

Hey all: don't miss the music button in the bottom right!!

You can play classical music on the simulated instruments. This is the nicest thing I've seen in a long time.

nthnclrk
0 replies
11h45m

Fun.

I went to the TLD and couldn’t make sense of how this is connected to that.

munzilla
0 replies
1d

As a musician, it's super interesting looking at the JS source (if you're a developer) and seeing how he applies musical concepts like notes and progressions to code.

miohtama
0 replies
22h44m

The sound does not seem to work on iPad?

lupire
0 replies
23h37m

Why is each string actually two strings next to each other?

joewferrara
0 replies
23h51m

The built in static, I'm not sure if it's purposeful or not, but I like it. If it is purposeful, it's a nice touch.

jessegavin
0 replies
1d1h

this! So fun to play with. Love that you can edit and reposition the strings.

Wonderful!

foota
0 replies
23h53m

I had a fun time making a game using MIDI with some friends for a game jam. There was a godot extension for MIDI (that I ended up mostly cannabalizing to get more control) and I used it to read and animate musical bars in a sort of guitar hero-y setup.

It was a fun project, although the game was a little rough around the edges to say the least.

ecjhdnc2025
0 replies
1d

Well that’s rather lovely.

djeastm
0 replies
1d

Bookmarked for stress-relief

cush
0 replies
1d

This is delightful! Thanks so much for sharing!

bassdigit
0 replies
1d1h

further idea: let strings resonate with the overtones of other strings being played

also: support different materials like steel/nylon/gut

LegitShady
0 replies
20h54m

reading some of the reactions to this, it amazes me how many free VSTs just need a web interface of some kind to suddenly become interesting and popular.

If you have a DAW there are so many interesting free sound generators on the internet. Just spitfire audio has their free lab VSTs which give you 60 VSTs to play with - and thats just one company.

https://labs.spitfireaudio.com/

Its all just missing the front end a DAW normally provides but is too complicated for people just looking to mess around with sounds.