tonguedrum.app v1.4
// modal synthesis in tempo reale · webaudio // 8 parziali inarmonici · corpo helmholtz // nessun campione · completamente procedurale

Modellazione fisica.
Nessun campione.

Otto parziali inarmonici per nota. Risonanza del corpo Helmholtz. Smorzamento non lineare che lascia alla velocità il potere di plasmare timbro e sustain. Vibrazione per simpatia tra lingue colpite e a riposo. Ogni suono è generato in tempo reale.

latenza<8ms
parziali/nota8
frequenza di campionamento44.1k
precisionefloat32
scale26
peso pagina<30 KB
registrazioneWAV · 2min
licenzaMIT
synth/modal-bank.ts
// 8 modal partials of a struck steel tongue:
// (1,1) fundamental + detuned beating partner,
// (2,1) (3,1) (1,2) (4,1) overtones, (5,1) shimmer.
const MODAL_MODES = [
  { ratio: 1.000, amp: 1.00,  Q: 800, type: 'fundamental' },
  { ratio: 1.001, amp: 0.08,  Q: 900, type: 'beating' },
  { ratio: 2.005, amp: 0.24,  Q: 600, type: 'overtone' },
  { ratio: 2.012, amp: 0.04,  Q: 500, type: 'beating' },
  { ratio: 2.998, amp: 0.07,  Q: 400, type: 'overtone' },
  { ratio: 3.520, amp: 0.03,  Q: 350, type: 'edge' },
  { ratio: 4.015, amp: 0.025, Q: 300, type: 'overtone' },
  { ratio: 5.98,  amp: 0.008, Q: 250, type: 'shimmer' },
];

function strike(note, velocity) {
  return MODAL_MODES.map((m) => ({
    freq:    note.freq * m.ratio,
    gain:    velocity * m.amp,
    Q:       m.Q,
    damping: nonlinear(velocity),
  }));
}