pantelisk 5 years ago

Hello hackernews!

I am the author! Wow, I can't believe the attention this is getting! Hopefully this proves to be useful as a tool, and not just as a JS demo! :)

The next plans are - redo drawing library to further improve performance! - polish a bit some audio plugins (like the paragraphic EQ) since some parts feel a bit off (the limiter, paragraphic eq for example). - Add some tutorials! Some things might not be straightforward like using Shift + [keys] for shortcuts etc. - Easier recording mode (like the ability to open a new empty audio project) - Multitrack mode, for more channels! - play a bit more with the concept of having different windows that can be in different screens (check out the frequency analyzer under "view")

To answer a few questions, I plan to have a very open license this is just a fun side project for me. but I need to figure out the licenses of some libs I am using first (eg wavesurfer, lzma-wasm) and do proper attribution!

Thanks again!

PS. I wrote this in 2018, and just kept it on my hard disk until recently, so certain features might be slightly different than back then :)

  • chpmrc 5 years ago

    This is one of the coolest web apps I've ever seen. How it handles multiple windows, docking, local drafts. Wow, well done!

  • Tade0 5 years ago

    The next plans are - redo drawing library to further improve performance!

    I'm amazed that you still have ideas regarding improvements here, because at least the selection performance is buttery-smooth even on a phone.

    Great job, very useful product.

    • BubRoss 5 years ago

      Soundforge on a 486 100Mhz was already pretty fast at editing a single track of audio. It's amazing how much heavy frameworks have warped our perception of normal interactivity.

      • Tade0 5 years ago

        I had a 486 and did some rudimentary audio editing back then.

        I remember the performance to be decent, but not 60fps-decent.

        But aside from that phones usually have relatively infrequent touch updates, which usually results in a single repaint on every such event, so 10FPS or so.

      • ssalazar 5 years ago

        And took more time and expertise to develop and only worked on one computing platform. The software industry has been a cycle of trading hardware performance improvements for developer productivity since the beginning.

  • padenot 5 years ago

    Hi, I work at Mozilla doing audio programming for Firefox, I see in your about page that you have issues with the Web Audio API, ping me (same nick a bit everywhere on the web, and also @mozilla.com) and we'll answer any question or fix any issue you have. Lots of things have happened in the audio space on the web since 2018!

    In particular, low latency (like native roundtrip latencies, so <10ms easy, but depending on the OS) no-jitter/real-real-time audio programming is now something that developers can do. Lock-free/wait-free programming and SIMD are coming in the next weeks/months.

    Very cool project in any case, I'll use it when I need to quickly do very high zoom on wave forms to debug things for Firefox.

    • kiviuq 5 years ago

      When can have we web midi (and no not sysex ;)

      Sooooo?

      • jacquesm 5 years ago

        Seconded, web midi is a big showstopper for Mozilla and should have more priority than the various bells and whistles that Mozilla does seem to prioritize but that ultimately are not part of a browser.

        Not being able to use Midi from FireFox means that for a whole raft of possible applications Chrome is the only option, which is a real pity.

        Please, please, pretty please, give web midi a higher priority.

        • TremendousJudge 5 years ago

          Curious, what applications need web midi?

          • Uninen 5 years ago

            Most music-related applications wanting to offer generic hardware support and hackability. Midi is an amazing standard. It allows you to hook up a synthesizer from the early 80s to your 2020 laptop (via a midi-capable audio interface) and control almost anything in your modern DAW (Digital Audio Workstation). And if your Web browser has support for it, control a software synth or any application as well.

            In addition to just musical instruments, a huge number of different hardware still use midi. I'm personally interested in DJ-world where things like DJ- and light-controllers use midi and therefore are very easily remappable and very hackable (if the sw is built correctly).

            I've wanted to build some DJ-related sw myself that would work via browser but the fact that currently only Chrome supports the standard has so far kept me off it. I'd very much like to see Firefox supporting Web midi.

            • TremendousJudge 5 years ago

              Right, I understand what MIDI is for, but usually music software has these real-time requirements on performance and the browser runs javascript, so... What are the applications for web midi? People aren't mixing their music on the browser nowadays, right?

              • dharma1 5 years ago

                You could have a whole DAW in the browser. There are already some web based synths

              • robbrown451 5 years ago

                I haven't seen significant problems from javascript being too slow on things that use web MIDI. Here is a web based "piano karaoke" app that runs quite well in browsers that support MIDI (and since it syncs with YouTube videos, it really kind of has to run in a browser vs native)

                https://www.youtube.com/watch?v=NV6rdmdZnkA

                Get in touch if you want to beta test it and let me know if you think it is fast enough on your set up, etc. Hoping to put it on "Show HN" soon. rjbrown at gmail More about it at https://pianop.ly/portfolio/

              • wheels 5 years ago

                Just to throw out an example from a friend's company: online piano lessons. MIDI input in the browser makes it possible for them to tell if you played the correct notes on your keyboard.

              • 8bitsrule 5 years ago

                If it was WebMIDI that actually transmitted -MIDI streams- (instead of just shoving them, with limited options, at some flaccid GM soundfile) that'd be really cool. Then you could choose your own MIDI playback engine (application, external hardware, ... ).

                In an environment that interprets -all- the codes, MIDI's almost unlimited. Hollywood's used it for a long time. It's very undemanding so people could -certainly- mix their music on the (right) browser. And, if people could add javascript routines to it? Ay-yay.

        • codemonkey-zeta 5 years ago

          The use of the phrase "bells and whistles" seems pretty ironic here.

          • colecut 5 years ago

            When you think of the web as a platform to be used for audio applications, it seems like a reasonable feature

            • qppo 5 years ago

              The thing is that "the web" doesn't make sense as a platform for audio applications when to build upon it you need to throw away realtime safe subroutines.

              Realtime audio rendering is a soft realtime problem. If the web audio APIs don't have methods for guaranteeing deadlines for rendering audio, it's only possible to build toy audio applications.

              I'm aware of things like bandlab and such. They're still toys and too limited for serious work, where the money is.

    • jcelerier 5 years ago

      Will we get jack support back on Linux one day ? :/

      • pseudosavant 5 years ago

        The mess with audio servers is one of the main reasons I could never stand Linux as my primary laptop OS. Jack, ALSA, OSS, Pulse, etc. Far too often the answer to my problem was that it didn't work on that specific audio server, or that I needed to compile my own server/kernel/app from source.

        Easily, reliably, and quickly playing audio is table stakes for Windows and Mac OS. They've been doing it for years. But instead of improving one or two audio APIs, on Linux it is time for a new audio server that will, but doesn't, solve all of the problems of every predecessor.

        • jcelerier 5 years ago

          > Easily, reliably, and quickly playing audio is table stakes for Windows and Mac OS. They've been doing it for years. But instead of improving one or two audio APIs, on Linux it is time for a new audio server that will, but doesn't, solve all of the problems of every predecessor.

          I mean, I have currently 5 soundcards on my desktop computer, 1 pro over PCIe, 2 pro over USB, 1 standard HD Audio and 1 output in my screen's HDMI, and I can assure you that even on windows it's definitely not a smooth ride between WASAPI, ASIO, MME, WDMKS... things crash or get stuck routinely, and I sometimes get random loud buzzes or no sound until I reboot. With my band we had tons of issues with a M-Audio card on windows fixating itself on the wrong sampling rate as soon as a desktop music playing was launched (this includes web browsers), entirely preventing playback on Ableton Live for instance.

          It's barely better on macOS, e.g. look at that shit: https://github.com/OSSIA/score/issues/778. macOS also sacrifices some low-latency when comparing the same hardware on it versus Linux (with raw ALSA or JACK) and Windows with ASIO.

          • rectang 5 years ago

            What exists as far as open source digital audio interfaces? Meaning only digital i/o — no analog.

            It seems like a relatively contained problem to take multiple streams of PCM audio into a computer, locked to word clock. Then the hard, fiddly aspects of analog design can be left to high-quality outboard converters which speak MADI or whatever.

            I say "contained" because I don't want to minimize the difficulty of getting such a design right, but it seems like you only have to get it right once.

            • nsajko 5 years ago

              Is USB not sufficient?

              • rectang 5 years ago

                What I'm looking for is a way to hook up any converter which outputs via a standard digital audio protocol (SPIDF, AES/EBU, ADAT lightpipe, etc.).

                Then we don't need a USB driver for each converter! We only need one USB driver, for the digital i/o interface. And we can polish the driver for that one interface until it's actually reliable, instead of relying on the sketchy one-off driver for this year's soon-to-be-obsolete USB audio interface.

                ETA: Many such converters (most of them high-end) listed here: https://www.sweetwater.com/c796--AD_DA_Converters

                • jcelerier 5 years ago

                  > SPIDF, AES/EBU, ADAT lightpipe, etc.

                  If I'm not mistaken the underlying transport protocol is the same for all of those - you can get a coaxial to XLR to get S/PDIF into an AES port or a coaxial to TOSLink converter to get S/PDIF data into an ADAT port.

                  You can look into the Madiface XT maybe ? https://www.rme-audio.de/hdspe-madi-fx.html or the other RME products which have enough digital I/O to cover a lot of needs

                  • nsajko 5 years ago

                    > If I'm not mistaken the underlying transport protocol

                    Some quick usage of Wikipedia suggest that you are, sadly, mistaken. ADAT lightpipe seems to use a completely different protocol (more capable?), and while S/PDIF and AES/EBU use quite similar protocols, they differ in impedance and max and min voltages, so I'm guessing that directly electrically connecting the two controllers is a bad idea for both the controller and the data.

                    • rectang 5 years ago

                      It doesn't matter for the purposes I'm investigating. So long as we can get the bits out of the wire and into open source software, we can make sense of them.

                      (Licensing could be a concern though if ADAT lightpipe is proprietary — I'm not clear on that. But then we could just use other open protocols instead.)

                  • rectang 5 years ago

                    In terms of i/o capability, the specs of the Madiface XT would work well for the purposes I'm proposing.

                    But the point is that I want open source drivers, and open source hardware! I don't want to depend on the health and the priorities of a commercial entity. I want to be able to inspect the driver software and contribute towards perfecting it!

                    Compared to, say, GPUs, the needs of multichannel digital audio i/o are modest and not changing very much over time.

          • ericlewis 5 years ago

            unrelated, but what do you use 5 sound cards for?

            • jcelerier 5 years ago

              I only have a "main" soundcard (the PCIe one) - HD audio and HDMI thing are unused 99% of the time, but if you have a computer more recent than 2007 you have them. The two USB soundcards are temporary and here currently because I need to test stuff for the sequencer I'm developing (https://ossia.io)

          • zamadatix 5 years ago

            I think the guy with 5 sound cards might be the exception that proves the rule - the conversation was about playing back audio from the browser not which OS starts to fall apart when you need a DAW for your band.

            • jcelerier 5 years ago

              > the conversation was about playing back audio from the browser

              well, no, the web audio API & stuff is explicitly being sold as something that will be equal in capability to other solutions, so definitely things used for pro audio.

            • 7952 5 years ago

              Even quite modest normal setups will have several input or output devices. Just on my laptop I have hdmi audio, built in speaker and mic, USB headset, bluetooth headset and remote audio from an RDP session.

        • nsajko 5 years ago

          My Chromium plays audio to my external and internal cards fine without Pulseaudio, I have just ALSA and don't know who still uses OSS (no judgement, I just use the default). I think your comment can only have an adverse effect on the conversation if you don't give specific examples.

          (Nitpick: Linux has nothing to do with Pulseaudio, it's just the kernel.)

        • nvarsj 5 years ago

          I've had many issues with OS X audio on Catalina - all of my USB audio devices skip and pop on it. It's also a pain to configure, with options bizarrely hidden in the MIDI app.

          Windows probably has the best audio stack of them all (battle tested, easy to use UX). In comparison, JACK/pulse are pretty good as well and people use it professionally. Like most things on Linux, the initial UX is a bit of a pain, but once you get past it you get amazing customization, even more so than Windows.

          These are the only abstractions I'm aware of on Linux systems - and they are simply built on top of ALSA which is the kernel's core sound API. Almost all desktop environments simply install PulseAudio, and you never have to worry about sound.

          • qppo 5 years ago

            How old is your Mac? That issue sounds very strange to me.

            CoreAudio is far and away the most impressive and powerful audio API across the board. It's ridiculous how much you can do with it and the abstractions it provides.

            It's also been better, faster, and supported lower latency than Windows up until WASAPI came around - you needed to use ASIO on Windows for years. Even today you can't programmatically change the sample rate of a device on Windows, which means that engines like RtAudio have to do resampling under the hood to support basic functionality that's been in CoreAudio.

            The only problem with it is that the documentation has evaporated. Which admittedly is a big one.

            • nvarsj 5 years ago

              > How old is your Mac? That issue sounds very strange to me.

              New MBP 16". Apparently it's a problem with the T2 security chip and affects almost all external USB 2.0/3.0 audio devices. Just do a google search for audio drop outs and T2. All digital audio goes through the T2 chip which seems to add latency and these drop outs. I think the only solution at the moment is to use a USB-C native device (but I haven't tested this). If you already have substantial hardware like I do, Catalina is basically unusable (and no fix in sight from Apple...).

              • qppo 5 years ago

                fwiw I don't think any audio manufacturer (hardware or software) has advised it "ok" to use Catalina, and OS upgrades have been a problem for as long as I've used professional audio tools.

                I understand with brand new machines it's a problem, but buying less-than battle tested hardware/software has always been problematic. If you already have substantial hardware, you probably shouldn't be buying a brand new machine and expecting it to just work after a major OS upgrade.

                • nvarsj 5 years ago

                  I shouldn't expect a widely used standard (USB Audio) to work after upgrading my hardware? All the Windows and Linux machines I've had have no problem with USB audio and I don't expect they ever will.

                  • qppo 5 years ago

                    I mean I can't even get (all) my USB audio gear to work properly on Linux, at all. For example system settings on Ubuntu Studio misinterpret anything with more than 2 channels as a surround device. But that's OK because the hardware manufacturer has advised they don't support Linux for their proprietary device management software because "widely used standard" like class compliant USB audio is not sufficient for their use case.

                    And I've been burned enough times by OS upgrades that I know to be cautious. I'm not saying the situation is good, just that it's a shitshow everywhere. I got around a dozen emails from my device and software vendors telling me not to use Catalina, so I'm not yearning to go out and buy a new Mac to run my software on and connect my hardware to it. I'll shit on Macs for that, but under the hood, CoreAudio is much more impressive than anything on Windows or Linux.

        • rhizome31 5 years ago

          After a bit of struggle I found that Pulseaudio over Jack adresses my needs. Music production software connects directly to Jack and all other software (browser, video player, etc.) uses Pulseaudio. Also the Cadence GUI really helps to set this up correctly.

      • padenot 5 years ago

        It's already enabled and lots of people use it, although it's not compiled in on the mozilla-provided builds (but downstream builders enable it).

        • tripzilch 5 years ago

          What really? How do I get it?

  • mikelpr 5 years ago

    politely asking for more formats too, it won't load my flacs

    • TheRealPomax 5 years ago

      presumably it loads whatever the browser can natively load. I don't think flac is one of those?

      • mbrock 5 years ago

        Chrome can load FLAC.

        • TheRealPomax 5 years ago

          Fair point, looks like FF also supports it.

  • idreyn 5 years ago

    Are you open to a couple of feature suggestions from someone who uses Audacity for scientific applications?

    1. An port of Audacity's "Noise Reduction" filter. I have done this once [0] (with some difficulty and no doubt with errors) and I am so tempted to just translate it to JavaScript and put up a PR, but I'm slammed right now.

    2. It would be very useful to be able to view the spectrograph as an alternative to the waveform, rather than having it live in a separate "spectrum analyzer" pane. Especially if zooming along the frequency axis were implemented, this would make it much more useful for, well, spectrum analysis.

    Thank you for making this. It's impressive in its own right but doubly so as a web application.

    [0] https://github.com/robin-labs/robin/blob/master/noisereduce/...

    • pantelisk 5 years ago

      Those are both great ideas, especially the noise reduction function might be something that makes this tool quite useful for quick recordings! I actually tried implementing noise reduction algorithms in the past, but sadly could not get it to work properly. Maybe time to revisit! (ditto about the spectograms too)

    • kevmo314 5 years ago

      Ooh, I actually was looking for a js noise reduction library recently. I might just translate it and put it up myself. :)

  • SanchoPanda 5 years ago

    Well done, and thanks for making it available so easily.

  • mestelan 5 years ago

    This is great, thanks. Is there a way to access the menu via a key shortcut?

    • pantelisk 5 years ago

      Right now no, but it would be very useful so i 'd like to add this, since you can use the keyboard to control the menu... (except well... opening it!). Any preferred key you 'd like this assigned to?

      • mestelan 5 years ago

        Great! No strong thoughts on a specific key. Maybe Shift-F, or Shift-F10? Or Esc-F, since another comment suggested Esc as a general prefix key?

  • asiachick 5 years ago

    Very cool.

    Any particular reason you're not using standard keys for cut/copy/paste/select all etc...?

    • pantelisk 5 years ago

      I did not want to bind control/command key as it is used by the browser itself (eg control + t opens a new tab). So instead I used the shift key, (so shift + A = select all, shift + C = copy, shift + V = paste, etc).

      • gfxgirl 5 years ago

        interesting choice to be different than all other webpages and user experience for no good reason.

        • pantelisk 5 years ago

          It is a non-optimal choice, but I believe there is a very strong reason. Not competing with the browser's native functionality.

          Some of the most horrible web experiences, occur because websites try to take control of native functions. For example "smooth" scrolling, or highjacking the back button, or trying to abuse the clipboard! Confusing the user, breaking navigation, making the page less accessible and in some cases breaking after X months when browser or OS behavior changes.

          What I have now is unfortunately far from "good" and there is improvement and experimentation waiting to happen, but the straight forward approach is not much better either...

          • asiachick 5 years ago

            What would you be competing with? Cmd/Ctrl-C/X/V for cut copy and paste are the norm. By allowing your app to use those keys you aren't overriding the browser, you're making your app conform to the standards. Even native apps do this. The OS may provide cut/copy/paste in an OS level text widget but it doesn't provide it in Word, Excel, Photoshop, or Audacity. That's up to the app. In the same way doing the same thing is up to the web app for anything not plain text.

            Most web major apps do this. Office365, Google Docs/Sheets/Slides. Even Facebook/Slack/Gmail since they re-interpret the text (converting :-) into emoji and or replace with images.

            • pantelisk 5 years ago

              Fair enough :) for cut/paste/copy it might definitely be a good option. Though what about control + S, should that prompt the export audio, or let the browser download the page?

              Perhaps I should add support for the control key, but let other combinations were conflicts might arise. Getting good UX is a such fascinating topic.

  • toastal 5 years ago

    You should make your modal/dialogs close when the escape key is pressed.

  • PatrolX 5 years ago

    No keyboard cut, copy and paste?

    • mestelan 5 years ago

      The keyboard shortcuts are signalled in the menu; they are Shift-C and Shift-V

  • brutt 5 years ago

    Please, specify license of your code, e.g. GPL3.

  • TheRealPomax 5 years ago

    Really hoping you add in spectrum editing, too, because waveforms are fine, but the power of RX and tools like it is that you can view the FFT spectrum and cull parts that are entirely useless (cutting out hums, >12k painful harmonics, etc =)

  • maxwellito 5 years ago

    Multi-track! That would be awesome! Take you time tho, keep the pleasure of working on it and don't say yes to all feature requests.

    Also, looking at the page load and see less than 80Kb transferred: this is absolutely beautiful! Amazing work!

  • Havoc 5 years ago

    Congrats!

pantelisk 5 years ago

Author again here! Now that this is finally sunsetting, I feel a bit more comfortable writing some things I 've learnt today!

- First of all, I am amazed at the suggestions and love this is getting. I have been dog fooding it by using it to quickly edit foley audio from a tascam hand-microphone device, in order to make some cheap sound effects for a game project I am working on. The point is, I thought I was aware of all bugs, and all areas of improvement, and I am humbled to have my mind opened and see how valuable outside perspectives are! It's so easy get tunnel vision and think you know best I guess.

- Secondly... as I said I wrote this in June 2018, and just... kept it... I guess I was afraid of sharing it to the world, perhaps the audio people would get mad at me for making mistakes with the audio api (like the fade in/fade out being linear). Perhaps the javascript people would make fun of me for just using Vanilla JS.

But if this is impressive in 2020, imagine how impressive it would have been back in 2018! So I guess my point is. Share your work! Do not be afraid to put it out there!

- If anyone is interested on how it is built, and how the interface complexities are managed, even though it is just plain old school JS that has the reputation of being notoriously difficult to maintain, I would be happy to make a write-up shortly, or perhaps give a talk on it.

- Third... (hopefully that is ok). If you like AudioMass, and like the way it is built and it performs, perhaps you might enjoy working together with me. We are doing cutting edge computer vision, and well.. some CRUD stuff too! My company is hiring (info in my profile). But please be advised that due to covid-19 things may take longer or may not be fully up to date.

PS. As for license, I will probably choose something like "wtfpl.net". if it can help you learn something, or build something, go ahead! If you noticed, the page doesn't have any tracking (I realy don't know how many visitors came (I also disabled nginx logs)). And of course no ads at all. I 'm just trying to build cool and useful stuff!

  • sam1r 5 years ago

    This is great! I’d love to help contribute. Would you be interested in adding flac support?

    Imagine the future interface with flac + svg + you’re already well-performant foundation with audio mass

    • pantelisk 5 years ago

      Yes! Flac support is important, thank you for the suggestion. I would expect it to be already supported https://caniuse.com/#search=flac and I am just using web audio functions it should decode fine (but it's not). Maybe I am overzealously filtering for formats!

      And performance is fine, but it can be so but soooo much better! Like just by adding sprinkling some wasm or asmjs in the "onaudioprocess" loops, to speed up the buffer traversing loops and escape the dreaded garbage collector!

  • llimllib 5 years ago

    I love the wtfpl, but I recommend the unlicense over it, esp for something semi-serious like this: https://unlicense.org/

    • pantelisk 5 years ago

      Thank you for the suggestion! Unlicense does seem much better and their website has a valid SSL cert, unlike the wtfpl one... So, this is probably the one! Will update the repo later tonight! Cheers!

      • rectang 5 years ago

        By choosing a rebel license like the WTFPL or Unlicense, you are going to limit your world of potential users and collaborators. There are people that do that deliberately, such as Doug Crockford and the JSON license, but if you're going to do that, you really should do it from a position of expertise.

        To maximize the reach of your program, you would be well-served to select one of top-ten or top-twenty popular FOSS licenses. I could provide a list but any list would be biased; just google it.

        I have my opinions about which FOSS license I would select, but I'm going to suppress them because I just want to help you ease into the mainstream.

        A decent way to choose would be to look at what community you want to be a part of and see what the predominant license choice is within that community.

        • neunnech 5 years ago

          Unlicense is not "a rebel license like the WTFPL".

  • antoncohen 5 years ago

    I'd avoid WTFPL if you are serious about this as an open source project.

    Google publishes their internal open source policy[1], i.e., what open source licenses can be used in Google software. I think it is a solid reference for what a good corporate open source policy is. It explains the reasoning, it isn't some crazy enterprise things that bans all open source (I've seen that), and it isn't some free-wheeling startup that allows everything with no scrutiny.

    They ban the use of WTFPL code[2], and ban contributions to WTFPL code.

    [1] https://opensource.google/docs/thirdparty/licenses/

    [2] https://opensource.google/docs/thirdparty/licenses/#wtfpl-no...

radiowave 5 years ago

Was really not expecting to be impressed by this, but it's excellent. The inclusion of a spectrogram is a very nice touch.

The ability to preview EQ changes while the audio is playing back is impresssive, although the x-axis scale on the parametric isn't helpful - everything below 1kHz is squashed into the left-most 10% of the plot.

Some small nitpicks are that it's currently quite fiddly to use the compressor without a gain reduction meter, and my usual bugbear with simpler audio editors: that fade-outs are almost never useful unless you can alter the curve.

But the fact that this is working so smoothly in a browser at all, and in Firefox to boot, is really commendable.

  • rectang 5 years ago

    It also has my usual bugbear in that fades are calculated linearly rather than logarithmically as humans actually perceive loudness. (Decibels are logarithmic for a reason.)

    How come so many apps get this wrong? This is really basic psychoacoustics, and linear fades sound terrible!

    > fade-outs are almost never useful unless you can alter the curve.

    I agree, but would like to add that you should be altering a logarithmic curve.

    • pantelisk 5 years ago

      You are 100% correct. I guess it's because it's a js developer doing audio, instead of an audio engineer doing js! So I have a lot to learn, most of the plugins have minor issues, but I 'll be focusing in correcting those when I get the chance!

      • vel0city 5 years ago

        I agree with the above posters. Things like normalize as well should also probably have their value expressed as dB as that's kind of the industry norm from what I understand.

        I do have to say, this is a super cool tool and I've definitely bookmarked it. I normally use tools like Audacity to quickly record, trim, and normalize audio tracks so this tool fits my use cases very well. Thanks for sharing!

      • rectang 5 years ago

        You're in good company! There are countless linear loudness controls out there. My "favorite" from years ago was Logic Audio. Hopefully they fixed it a long time ago.

  • qppo 5 years ago

    > The ability to preview EQ changes while the audio is playing back is impresssive

    Comments like this surprise me, but probably because the lightest weight thing I'll spin up for audio work is Reaper.

    The idea of anything but online rendering for user controlled DSP wouldn't cross my mind - it always aggravates me when I have to do it (there's a few older tools I use where it's the only way to do things like time/pitch edits).

    > everything below 1kHz is squashed into the left-most 10% of the plot

    Very specifically you want a semilog plot (use center bin frequency, not edge of the bin to avoid the 0 problem) or if you're really fancy, constant-Q/mel/bark scales. Grid should be Frequency = [(1:9)e(1:3),10e3 20e3], Magnitude = [-96:6:0].

    Very helpful if you use an exponential average on the bins for meter ballistics.

    • radiowave 5 years ago

      What was notable to me about the live preview is that a browser-based tool was able to do it convincingly - not that it's an impressive feature per se.

  • elwell 5 years ago

    It's quite impressive. Dare I have the audacity to say it rivals Audacity?

jjice 5 years ago

We have Photopea (https://www.photopea.com/) for images, and now we have AudioMass for audio. I love these open source, web based tools that work fantastic. Great job!

  • detaro 5 years ago

    Wait, Photopea is open source?!

    • edoceo 5 years ago
      • detaro 5 years ago

        That's a repo with a Readme and 4 image files for the logo...

        • djsumdog 5 years ago

          Yes, and it clearly says it's not open source in the README:

          > Since Photopea is not fully open-source, this account serves as a place for bug reports and general discussion.

        • edoceo 5 years ago

          Yep, that's what I was showing. It's got a GitHub but it's not FOSS

          • kupopuffs 5 years ago

            Just a link is not really showing. Everyone knows nobody clicks on the links, we demand instant explanations!

  • ehsankia 5 years ago

    Now just need a solid video editor!

  • themodelplumber 5 years ago

    Along similar lines, I have been wondering if there are any web-based DAWs or 3D modeler-renderers to check out. It seems like it's probably only a matter of time at this point, anyway. Even if not FOSS, open formats would be great.

mrspeaker 5 years ago

Wow, that's fantastic... one thing I noticed instantly is that (to me) the UI/UX is so intuitive. I use Audacity a lot, and the UI on that for core operations: zooming, unzooming, trimming, selecting... is so much more clunky (I can never figure out how to "unzoom") - it drives me mad every time.

This one one intuitive and natural. I'd have to evaluate how file system handling worked, but just based on the UI and snappiness - I'd use this over Audacity for any quick-n-dirty audio editing tasks. Really cool!

  • bbx 5 years ago

    Agreed. Audacity is great for quick audio editing but the selecting/dragging/zooming experience is quite annoying. It would be great to have Ableton’s bird-eye view feature, it’s super intuitive and really responsive.

ArtWomb 5 years ago

Works great! Near-native web audio on the horizon ;)

High Performance Web Audio with AudioWorklet in Firefox 76

https://hacks.mozilla.org/2020/05/high-performance-web-audio...

  • Tade0 5 years ago

    I hope it lives up to its promises - one thing I noticed is using Web Audio on mobile devices is that I get sudden drops and crackling even with the simplest configurations which can't possibly affect the CPU to the point where they are the root cause.

    Interestingly, no such issues on desktop - at least not until I add some heavy processing.

dpflan 5 years ago

This is the GitHub repo: https://github.com/pkalogiros/audiomass (accessible under the "help" menu)

  • skyfaller 5 years ago

    Looks like they haven't added a license yet. I hope they do, if this is intended to be an open source project. https://github.com/pkalogiros/AudioMass/issues/1

    • dpflan 5 years ago

      Absolutely agree: the repo is active so waiting a license to be pushed.

    • contravariant 5 years ago

      They're telling people to please checkout the repo and have fun, which I think is almost a license in and of itself (of course you are then legally obliged to have fun should you choose to use the license), but explicit is better than implicit in these cases.

      • Wowfunhappy 5 years ago

        "Checkout and have fun" does not say anything about redistribution, however.

city41 5 years ago

It appears the entire app was written with vanilla JS. That's just an observation. I wouldn't have expected that nowadays.

The app is super impressive!

  • jacquesm 5 years ago

    That's a huge plus in my book. Frameworks tend to obscure what the application actually does because there is orders of magnitude more framework code than there is application code, and frameworks tend to be very indirect when going about their business with 12 different layers hit for a simple operation.

    • city41 5 years ago

      As a counter, if you look at the code, there's a lot of DOM api calls littered throughout which obscure what is going on. This could be relieved by pulling out the DOM manipulation into common constructs that all parts of the app use, but then you're creating your own framework/library and might be better off using a battle tested one.

      • lucideer 5 years ago

        Given how responsive the UI is compared to most modern UIs built in the "battle tested" frameworks & libraries, I suspect the recommendations in this comment are all well and good in theory, but not necessarily reflective of reality in practice.

bvm 5 years ago

Reminds me of the audio editor that shipped with Windows...95? Had some great times with that thing reversing everything in earshot, doing reverse reverb etc etc

edit: this thing https://i.imgur.com/UXqSteO.png

  • rpastuszak 5 years ago

    Ha, I remember how proud I was when I discovered a "hack" to increase the max recording duration (from 30s to X minutes[⋆]):

    1. record silence

    2. copy paste the recording till you achieve the desired length

    3. start recording from the beginning

    On AudioMass and its performance/snappiness: this feels much more smooth than Audacity on my MBP, so I'll give it a shot soon.

    ⋆ or: whatever the memory limitations of your PC were

  • Jaruzel 5 years ago

    sndrec32.exe - I think it's last appearance was Windows XP (or maybe 7, I don't have either to check).

    It a shame it's gone tbh, it was a REALLY quick way to just playback an audio file, without all that extra baggage that later playback apps had (iTunes clones).

ctrager 5 years ago

Please forgive me for being self-centered. I DO think AudioMass is great. I'm running it locally and I even contributed by posting a legit issue in github. But here's the self-centered part: The other day I posted a "Show HN" for something web audio related that I wrote and got crickets so I'd like to try again: https://ctrager.github.io/music_tools. Especially check out "Pitch Detector". All three tools are standalone single HTML files that don't need a server.

  • ximeng 5 years ago

    These are interesting tools. Pitch detector didn't seem to work too well for me but no doubt my bad singing. You could probably just show both clefs with the relevant clef symbol at the beginning rather than making it an option. For the beat detector, it would be interesting to see average distance from the beat in order to try to improve. It could be a game following a rhythm easily.

    Think for HN you probably need a quick demo that will attract more of the large number of people who are not necessarily going to use this tool long term. Give people a hook. Also keep trying, because it's pretty random what gets voted up on any one day. I think with some development and innovation this could be a useful tool. You've also not got any contact info which makes it harder for interested people to get in touch if they like your stuff.

    • ctrager 5 years ago

      I can't really make it work with singing either, but it works well when I play violin. My motivation is just pitch, to give feedback to me playing violin or my wife trying to learn viola.

      • Cactus2018 5 years ago

        Check out "Intonia", works brilliantly with stringed instruments

        • ctrager 5 years ago

          I had tried it briefly because my favorite youtube violin teacher Beth Blackerby recommended it in one of her videos, and it's great. But, I wanted the experience of coding something myself (I'm retired, hadn't coded in four years, lockdown has made me antsy) and I wanted something that was a standalone single HTML file, and I wanted something that felt easier. So, I ignore the time dimension and paint the notes on the staff the way a player is used to reading them rather than Intonia's interface which looks more technical.

    • ctrager 5 years ago

      All the tools have links at the bottom to their respective github repos, so contact via github.

  • dang 5 years ago

    Part of your problem is that you submitted a list (https://news.ycombinator.com/item?id=23309642). Lists tend not to do as well on HN because, at the level of the list itself, there isn't that much that's interesting to discuss—just the lowest common denominator of the items on the list (https://hn.algolia.com/?dateRange=all&page=0&prefix=true&que...). If you email hn@ycombinator.com we can give you some tips on how to repost!

    Edit: another way I like to look at this is that HN itself is a list, and posting a list to a list adds a layer of indirection that mostly never gets traversed.

  • severak_cz 5 years ago

    I actually looked into code of your metronome to see how did you solve timing issues. I once tried to implement drum machine in JS and run into that setTimeout/setInterval are very very relaxed about precision.

mikece 5 years ago

My first thought: add WebRTC voice chat and the ability to record all participants in separate channels... would be awesome for podcast recording!

anigbrowl 5 years ago

8/10, very promising. feels like Cooledit/Audition, which was for a long time the best of its class (Pro T Tools is the industry standard but that's based on long years of hardware-lock-in). Allow local instances and add Lua or similar user scripting and you've got a winner. Well done.

croisillon 5 years ago

May I ask, what the sample music is? Sounds like a movie score but Shazam doesn't recognizes it.

  • pantelisk 5 years ago

    Haha, it's something I wrote a long time ago (around 10 years back). I wrote it in Cubase and if I recall correctly Symphobia was the primary VST used. I had way more time back then for music than I do now. If you like the piece feel free to grab it (test.mp3 in the github repo). Cheers!

    • croisillon 5 years ago

      Thanks! It's a bummer though: it sounds like a movie I'd like to watch :D

gtm1260 5 years ago

I open Audacity about once every 3 months for some random audio editing, this is definitely a better/more intuitive app. Plus web based is awesome for something I use so infrequently. Great Work!

  • svth 5 years ago

    Don't knock Audacity, though. Fantastically useful piece of software.

false_kermit 5 years ago

Very cool! I tried doing some signal processing stuff back in the day and got absolutely discouraged after discovering how much linear algebra was involved.

I particularly appreciate the ability to preview compression. Compression is probably what I use most when I'm editing audio and having that at my fingertips without loading Audacity or Ableton would be super nice for quick, rough changes.

One thing that I'd really like to see would be a de-essing plugin, or even better a multiband compressor.

thinkloop 5 years ago

These are the exact tools I am constantly looking for. Full browser sandbox for no stress "install", local-first, offline-first, so you own your own data - then option for locally encrypted cloud backups. I am almost 100% web now, I use very few installed programs and am constantly trying to get that to zero. One day someone is going to collect all these best-in-class web tools and make a proper chromebook where the user owns their own data.

kethinov 5 years ago

This would make a good Electron app so it can also be used offline by regular people who don't want to or are unable to fuss with command line web servers.

TheSpiceIsLife 5 years ago

I dabble from time to time with mixin rekids, and am presently trying to find an audio editor for simple cut n paste that Audacity. Must support MacOS.

What's is out there? My DuckFu is letting me down in this instance.

I'll give AudioMass a spin over the weekend, and like others have said if it could be a standalone Electron-based app that would probably work, and happy to throw a few antipodean dineros at it.

andoma 5 years ago

Features vs page load time is very impressive.

  • vezycash 5 years ago

    According to the about page, it's 65KB.

dharma1 5 years ago

Would be great if there was a VST like standard for audio effect plugins for web, so that many web-based audio apps could use the same plugins.

Saw something like that but for synths - https://www.webaudiomodules.org/wamsynths/

  • pantelisk 5 years ago

    That's insane! I 'm actually working on a lite-daw for web, so this is extremely interesting to me. However I do not plan to go very far. My angle is that this should be a tool to experiment and try out things with minimal friction, then for any serious work, perhaps users can look into professional solutions. Perhaps also take advantage of the web's collaborative nature and have multiple users share a session!

    There are decades of research, feedback loops and work put into tools such as FruityLoops, Cubase, ProTools etc, and the thought of reimplementing parts of it for web is such a daunting task.

    • dharma1 5 years ago

      Multiplayer would be sweet for a web DAW, it rocks in design tools like Figma.

      I think you are right, a light DAW would cover 80% of people's needs. And as long as you can export the track as midi and audio bounces, you could always continue it in a native DAW.

      I would love to collab if you need UI/UX for this btw? I've worked on audio and DAW stuff for a long time, as well as open source. What's the best way to reach?

_benj 5 years ago

this brings me back to the days of cool edit pro! (Idk why!) but it is amazing that you can do that in a browser nowadays!

If I were to be super critical my only pet peeve has to do with the style of the menu :P The color (dark on light) seems disconnected from the rest of the app design and those big rounded corners gives the app a little bit of a toy-ish look (My point of reference for "pro" is something like Adobe Audition, Presonus StudioOne, Pro Tools, etc... kind of look) But that is just a personal preference (this is the radius I'm talking about https://github.com/pkalogiros/AudioMass/blob/master/src/main...)

But the project look awesome! keep it up!

ubercow13 5 years ago

Does this load the whole file into memory while it's being worked on? What if you tried to load a file that is too big? I wonder with these more complex productivity web-apps becoming more common, how something like a video editor might work that needs to work on data too large to put in memory.

  • pantelisk 5 years ago

    Yes, it is all in memory. I am taking advantage for IndexDB for local drafts. And localstorage for plugin presets. But it does not match the flexibility of being able to create lots of big uncompressed files and cache in the disk while workign on a project.

    So everything needs to use lower fidelity settings, or do things like compress WAV files in a lossless way with LZMA since other avenues are too heavy. I am not seeing this becoming something like Audacity or Audition replacement, but a quick tool for modifying audio files on the fly.

kpmah 5 years ago

Very nice! I've recently tried covering some similar ground for a side project (https://forkjam.com/new) so I have an idea of how much work this is.

I take it you took the approach of using WASM for audio decoders?

andai 5 years ago

This is really cool, thanks for sharing!

I'm noticed my CPU fan at full blast and checked my processes (then Chrome task manager), I had left it open an it was using 80-95% CPU in the background.

Tested again, it seems to be the spectrum analyzer (even after I pause playback, or close the analyzer window).

jacquesm 5 years ago

This is smack in the path of Audacity, very nice work. Is it possible to load midi synchronized to an audio file? That's a weak point in Audacity, it can't really edit the midi as you go through the audio and for some tasks that would be extremely useful to have.

PdTheTech 5 years ago

This is awesome. As an avid past user of Cool Edit 2000 and Adobe Edition 1.5, I love this project. Fantastic to see something familiar in a browser. As a bonus it hits me right in the nostalgia. I'll be watching and supporting this!

soperj 5 years ago

If i could suggest anything it would be a way to make a selection while playing. Like hold down shift, press space bar, and then press space bar again, and it's all selected.

dintech 5 years ago

This is great! When working with large files, I'd like zoom in/out to be a bit snappier. I'd also like right click -> zoom to selection.

inflam52 5 years ago

Great work!!! I've been wanting to do something like this for a while. I'm glad someone is leveraging the web to build a real open source DAW!

maxwellito 5 years ago

Very simple, but clean, works like a charm, perfect set of effect and import/export features. I need to check if it works as a PWA.

Kudos to the creator!

kube-system 5 years ago

When I try to play the sample in Brave I only get sound for a couple of seconds before it goes quiet. In FF it works correctly.

kevindeasis 5 years ago

It took me a few seconds on how to use this, but once I figured it out, I was like, damn, this is pretty cool!

I wish there was a cli for this

waprin 5 years ago

Really great project, nice job author, hoping to use it as a starting point/inspiration for some projects of my own.

wigl 5 years ago

I would love the ability to label and extract sections like in audacity! That’s the only thing missing from my use case

  • pantelisk 5 years ago

    You can extract sections (as mp3 by selecting, and then File > Extract mp3 > current selection). Or File > Save Local Draft (and you can open the selection as a standalone audio project).

    Being able to label things with markers and different colors though would be fantastic! It's in the plans, once a bit better audio handling of slices (eg cross-fading, mix-dragging etc) is added!

    • wigl 5 years ago

      I noticed that and I do think it is nice. I have to extract and transcribe long sequences, so it would be nice to have the audacity label track feature to bookmark/label a bunch of sections and then output them as individual files named by their label along with a .txt. This is audacity's format:

      start end label_name

      1.02302 2.23193 label_1

      You could take it further and have some numeric labeling (audacity doesn't autofill) and that'd be even nicer. This would be super helpful for working with speech processing data. Regardless, keep up the good work!

dsco 5 years ago

Now slap cloud storage, collaborative editing/highlighting and paid accounts on it - this is impressive software!

12bits 5 years ago

This looks really cool, by the nature of my user name I must greedily request vintage sampler modes. :)

goodmachine 5 years ago

Impressive. Back in the day, SoundEdit16 was the thing. I hope they clone or skin it like that

jugg1es 5 years ago

Impressive - always amazed at the low-level stuff you can do in browsers nowadays. Nice job.

bulldog13 5 years ago

How do I delete a highlighted section? I feel like I am missing something simple.

cjohansson 5 years ago

Amazing stuff, thanks for sharing. Works great in my iPhone 6 browser

deeblering4 5 years ago

This us great! Kinda reminds me of cool edit pro (two point oooooh)

pea 5 years ago

Awesome - kind of reminds me of the Renoise interface!

dharma1 5 years ago

nice, was just looking for a free audio editor and could only find things that look like they're from the 90's (Audacity).

.wav export would be grand!

01walid 5 years ago

For a second I thought this is a WebAssembly app :)

Nice job!

suyash 5 years ago

Good job, like to see some good tutorials.

aswanson 5 years ago

The UI is cool looking.

xchip 5 years ago

thanks!

microcolonel 5 years ago

It'll be very fun over the years, for whoever is tasked with it, to fix all of the bugs bugs common to audio editors like this.

My favourite one is how, depending on when, resizing the selection while playing with loop enabled can cause the cursor to escape the selection (!). That was the first one I checked for when I opened this up.