{"id":5937,"date":"2026-04-14T09:57:31","date_gmt":"2026-04-14T09:57:31","guid":{"rendered":"https:\/\/composers-inside-electronics.net\/cie-wp20\/?p=5937"},"modified":"2026-04-16T01:55:38","modified_gmt":"2026-04-16T01:55:38","slug":"ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution","status":"publish","type":"post","link":"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/","title":{"rendered":"AI on &#8220;generate a web page to select an audio clip to play through a selected impulse convolution&#8221;"},"content":{"rendered":"\n<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_84 counter-hierarchy ez-toc-counter ez-toc-grey ez-toc-container-direction\">\n<p class=\"ez-toc-title\" style=\"cursor:inherit\">Table of Contents<\/p>\n<label for=\"ez-toc-cssicon-toggle-item-6a28a7a9615f6\" class=\"ez-toc-cssicon-toggle-label\"><span class=\"\"><span class=\"eztoc-hide\" style=\"display:none;\">Toggle<\/span><span class=\"ez-toc-icon-toggle-span\"><svg style=\"fill: #999;color:#999\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"list-377408\" width=\"20px\" height=\"20px\" viewBox=\"0 0 24 24\" fill=\"none\"><path d=\"M6 6H4v2h2V6zm14 0H8v2h12V6zM4 11h2v2H4v-2zm16 0H8v2h12v-2zM4 16h2v2H4v-2zm16 0H8v2h12v-2z\" fill=\"currentColor\"><\/path><\/svg><svg style=\"fill: #999;color:#999\" class=\"arrow-unsorted-368013\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"10px\" height=\"10px\" viewBox=\"0 0 24 24\" version=\"1.2\" baseProfile=\"tiny\"><path d=\"M18.2 9.3l-6.2-6.3-6.2 6.3c-.2.2-.3.4-.3.7s.1.5.3.7c.2.2.4.3.7.3h11c.3 0 .5-.1.7-.3.2-.2.3-.5.3-.7s-.1-.5-.3-.7zM5.8 14.7l6.2 6.3 6.2-6.3c.2-.2.3-.5.3-.7s-.1-.5-.3-.7c-.2-.2-.4-.3-.7-.3h-11c-.3 0-.5.1-.7.3-.2.2-.3.5-.3.7s.1.5.3.7z\"\/><\/svg><\/span><\/span><\/label><input type=\"checkbox\"  id=\"ez-toc-cssicon-toggle-item-6a28a7a9615f6\"  aria-label=\"Toggle\" \/><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#Initial_version_From_Google_AI_Mode\" >Initial version From Google AI Mode<\/a><ul class='ez-toc-list-level-2' ><li class='ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#Core_Components\" >Core Components<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#Implementation_Guide\" >Implementation Guide<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#1_HTML_Structure\" >1. HTML Structure<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#2_JavaScript_Logic\" >2. JavaScript Logic<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#Key_Considerations\" >Key Considerations<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-1'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#Refinement_%E2%80%93_generate_html_and_js_for_a_web_page_to_select_an_audio_clip_to_play_through_a_selected_impulse\" >Refinement &#8211; generate html and js for a web page to select an audio clip to play through a selected impulse<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#1_HTML_Structure-2\" >1. HTML Structure<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#2_JavaScript_Logic_appjs\" >2. JavaScript Logic (app.js)<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#Key_Technical_Details\" >Key Technical Details<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#How_to_Run\" >How to Run<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-12\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#Local_for_debugging_and_development\" >Local for debugging and development<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-13\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/#From_browser_over_internet\" >From browser over internet<\/a><\/li><\/ul><\/li><\/ul><\/li><\/ul><\/nav><\/div>\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"Initial_version_From_Google_AI_Mode\"><\/span>Initial version From Google AI Mode<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n\n<p class=\"wp-block-paragraph\">To create a web page that allows users to select an audio clip and apply different impulse convolutions (reverb effects), you can use the <strong>Web Audio API<\/strong>. This API provides a <code>ConvolverNode<\/code> specifically designed to simulate acoustic spaces by processing an audio source with an <strong>impulse response (IR)<\/strong> file.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"Core_Components\"><\/span>Core Components<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>AudioContext<\/strong>: The environment where all audio processing happens.<\/li>\n\n\n\n<li><strong>AudioBufferSourceNode<\/strong>: Loads and plays your selected audio clip.<\/li>\n\n\n\n<li><strong>ConvolverNode<\/strong>: Applies the mathematical convolution of the IR to the audio.<\/li>\n\n\n\n<li><strong>GainNode<\/strong>: Controls the &#8220;wet&#8221; (effect) and &#8220;dry&#8221; (original) signal levels.<\/li>\n<\/ol>\n\n\n\n<h2 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"Implementation_Guide\"><\/span>Implementation Guide<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">You can build this using a simple HTML structure with a <code>&lt;select&gt;<\/code> dropdown for both your audio clips and your impulse responses.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"1_HTML_Structure\"><\/span>1. HTML Structure<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">Create a simple interface with dropdowns and a play button.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;label for=\"audioSelect\"&gt;Choose Audio Clip:&lt;\/label&gt;\n&lt;select id=\"audioSelect\"&gt;\n  &lt;option value=\"drums.wav\"&gt;Drum Loop&lt;\/option&gt;\n  &lt;option value=\"vocals.wav\"&gt;Vocals&lt;\/option&gt;\n&lt;\/select&gt;\n\n&lt;label for=\"irSelect\"&gt;Choose Impulse Response:&lt;\/label&gt;\n&lt;select id=\"irSelect\"&gt;\n  &lt;option value=\"hall.wav\"&gt;Large Hall&lt;\/option&gt;\n  &lt;option value=\"room.wav\"&gt;Small Room&lt;\/option&gt;\n  &lt;option value=\"plate.wav\"&gt;Plate Reverb&lt;\/option&gt;\n&lt;\/select&gt;\n\n&lt;button id=\"playBtn\"&gt;Play with Effect&lt;\/button&gt;\n<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"2_JavaScript_Logic\"><\/span>2. JavaScript Logic<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">The script handles fetching the audio files as <code>ArrayBuffers<\/code>, decoding them into <code>AudioBuffers<\/code>, and routing them through the <code>ConvolverNode<\/code>.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const audioCtx = new (window.AudioContext || window.webkitAudioContext)();\nlet convolver = audioCtx.createConvolver();\n\nasync function getBuffer(url) {\n  const response = await fetch(url);\n  const arrayBuffer = await response.arrayBuffer();\n  return await audioCtx.decodeAudioData(arrayBuffer);\n}\n\nasync function playAudio() {\n  <em>\/\/ Resume context for browser security<\/em>\n  if (audioCtx.state === 'suspended') await audioCtx.resume();\n\n  <em>\/\/ Load selected files<\/em>\n  const audioFile = document.getElementById('audioSelect').value;\n  const irFile = document.getElementById('irSelect').value;\n\n  const source = audioCtx.createBufferSource();\n  source.buffer = await getBuffer(audioFile);\n  \n  convolver.buffer = await getBuffer(irFile);\n\n  <em>\/\/ Route: Source -&gt; Convolver -&gt; Destination (Speakers)<\/em>\n  source.connect(convolver);\n  convolver.connect(audioCtx.destination);\n  \n  source.start();\n}\n\ndocument.getElementById('playBtn').addEventListener('click', playAudio);\n<\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"Key_Considerations\"><\/span>Key Considerations<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>Impulse Response Source<\/strong>: You can find free IR files on sites like Reverb.js.<\/li>\n\n\n\n<li><strong>Normalization<\/strong>: By default, the <code>convolver.normalize<\/code> property is <code>true<\/code>, which helps maintain consistent volume regardless of the IR file&#8217;s gain.<\/li>\n\n\n\n<li><strong>Dry\/Wet Mix<\/strong>: To allow users to adjust the intensity, connect the source to both the destination (Dry) and the convolver (Wet) using separate <code>GainNodes<\/code>.<\/li>\n<\/ul>\n\n\n\n<p class=\"wp-block-paragraph\">Would you like a more <strong>advanced version<\/strong> that includes a <strong>visual waveform display<\/strong> or <strong>real-time dry\/wet sliders<\/strong>?<\/p>\n\n\n\n<h1 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"Refinement_%E2%80%93_generate_html_and_js_for_a_web_page_to_select_an_audio_clip_to_play_through_a_selected_impulse\"><\/span>Refinement &#8211; generate html and js for a web page to select an audio clip to play through a selected impulse<span class=\"ez-toc-section-end\"><\/span><\/h1>\n\n\n\n<p class=\"wp-block-paragraph\">Used prompt to Gemini &#8220;generate html and js for a web page to select an audio clip to play through a selected impulse&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Response as follows&#8230;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">To create a web page that performs impulse response convolution, you can use the <strong>Web Audio API<\/strong>. This involves loading two audio files: your &#8220;dry&#8221; source (the clip) and your &#8220;impulse&#8221; (the acoustic fingerprint of a space).<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Below is a clean, functional implementation based on the concepts discussed in the <a target=\"_blank\" rel=\"noreferrer noopener\" href=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/ai-on-generate-a-web-page-to-select-an-audio-clip-to-play-through-a-selected-impulse-convolution\/\">Composers Inside Electronics (CIE) documentation<\/a>.<\/p>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"1_HTML_Structure-2\"><\/span>1. HTML Structure<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">This setup provides dropdowns for your files and a master &#8220;Play&#8221; button. Note that for this to work, your audio files must be hosted on the same server or a server with CORS enabled.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">HTML<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;!DOCTYPE <strong>html<\/strong>&gt;\n&lt;html lang=\"en\"&gt;\n&lt;head&gt;\n    &lt;meta charset=\"UTF-8\"&gt;\n    &lt;title&gt;Audio Convolution Lab&lt;\/title&gt;\n    &lt;style&gt;\n        body { font-family: sans-serif; padding: 20px; line-height: 1.6; }\n        .control-group { margin-bottom: 15px; }\n        label { display: block; font-weight: bold; }\n        button { padding: 10px 20px; cursor: pointer; background: #007bff; color: white; border: none; border-radius: 4px; }\n    &lt;\/style&gt;\n&lt;\/head&gt;\n&lt;body&gt;\n\n    &lt;h2&gt;Convolution Reverb Player&lt;\/h2&gt;\n\n    &lt;div class=\"control-group\"&gt;\n        &lt;label for=\"audioSelect\"&gt;Source Audio:&lt;\/label&gt;\n        &lt;select id=\"audioSelect\"&gt;\n            &lt;option value=\"drums.wav\"&gt;Drum Loop&lt;\/option&gt;\n            &lt;option value=\"vocals.wav\"&gt;Vocals&lt;\/option&gt;\n        &lt;\/select&gt;\n    &lt;\/div&gt;\n\n    &lt;div class=\"control-group\"&gt;\n        &lt;label for=\"irSelect\"&gt;Impulse Response (Space):&lt;\/label&gt;\n        &lt;select id=\"irSelect\"&gt;\n            &lt;option value=\"hall.wav\"&gt;Large Concert Hall&lt;\/option&gt;\n            &lt;option value=\"cathedral.wav\"&gt;Cathedral&lt;\/option&gt;\n            &lt;option value=\"plate.wav\"&gt;Vintage Plate&lt;\/option&gt;\n        &lt;\/select&gt;\n    &lt;\/div&gt;\n\n    &lt;button id=\"playBtn\"&gt;Play with Effect&lt;\/button&gt;\n\n    &lt;script src=\"app.js\"&gt;&lt;\/script&gt;\n&lt;\/body&gt;\n&lt;\/html&gt;\n<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"2_JavaScript_Logic_appjs\"><\/span>2. JavaScript Logic (<code>app.js<\/code>)<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">This script handles the asynchronous loading of audio data and the routing of the <strong>ConvolverNode<\/strong>.<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">JavaScript<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>const audioCtx = new (window.AudioContext || window.webkitAudioContext)();\nlet currentSource = null;\n\n\/\/ Helper function to fetch and decode audio files\nasync function getBuffer(url) {\n    const response = await fetch(url);\n    const arrayBuffer = await response.arrayBuffer();\n    return await audioCtx.decodeAudioData(arrayBuffer);\n}\n\nasync function playAudio() {\n    \/\/ Stop previous playback if it exists\n    if (currentSource) {\n        currentSource.stop();\n    }\n\n    \/\/ Resume context (required by browsers for user-initiated audio)\n    if (audioCtx.state === 'suspended') {\n        await audioCtx.resume();\n    }\n\n    \/\/ 1. Get selected file paths\n    const audioFile = document.getElementById('audioSelect').value;\n    const irFile = document.getElementById('irSelect').value;\n\n    \/\/ 2. Load buffers\n    const sourceBuffer = await getBuffer(audioFile);\n    const impulseBuffer = await getBuffer(irFile);\n\n    \/\/ 3. Create Nodes\n    const source = audioCtx.createBufferSource();\n    const convolver = audioCtx.createConvolver();\n    \n    source.buffer = sourceBuffer;\n    convolver.buffer = impulseBuffer;\n\n    \/\/ 4. Routing: Source -&gt; Convolver -&gt; Speakers\n    source.connect(convolver);\n    convolver.connect(audioCtx.destination);\n\n    \/\/ 5. Start playback\n    source.start();\n    currentSource = source;\n}\n\ndocument.getElementById('playBtn').addEventListener('click', playAudio);\n<\/code><\/pre>\n\n\n\n<hr class=\"wp-block-separator has-alpha-channel-opacity\"\/>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"Key_Technical_Details\"><\/span>Key Technical Details<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>ConvolverNode<\/strong>: This is the heart of the effect. It performs a mathematical operation called convolution, which multiplies the input signal by the impulse response in the time domain.<\/li>\n\n\n\n<li><strong>Impulse Response (IR)<\/strong>: Ensure your IR files are short, high-quality <code>.wav<\/code> or <code>.aif<\/code> files. Long IRs (like 10-second cathedrals) require more CPU processing.<\/li>\n\n\n\n<li><strong>Dry\/Wet Mix<\/strong>: To hear the original sound mixed with the reverb, you would typically add a <strong>GainNode<\/strong> for the &#8220;Dry&#8221; signal (Source -> Destination) and another for the &#8220;Wet&#8221; signal (Source -> Convolver -> Destination).<\/li>\n\n\n\n<li><strong>Normalization<\/strong>: By default, <code>convolver.normalize<\/code> is set to <code>true<\/code>, which attempts to prevent the volume from exploding when applying dense reverbs.<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"How_to_Run\"><\/span>How to Run<span class=\"ez-toc-section-end\"><\/span><\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">The initial version just has the first &#8220;drums&#8221; and &#8220;hall&#8221; file.<\/p>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"Local_for_debugging_and_development\"><\/span>Local for debugging and development<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">Files  in ~\/Dropbox\/PY\/CONVOLVER_PAGE<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>app.js\nconvolver.html\ndrums.wav\nhall.wav<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">From terminal &#8220;sh&#8221;&#8230;<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>python -m http.server 8000<\/code><\/pre>\n\n\n\n<p class=\"wp-block-paragraph\"> <a href=\"http:\/\/localhost:8000\/convolver.html\">http:\/\/localhost:8000\/convolver.html<\/a><\/p>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"From_browser_over_internet\"><\/span>From browser over internet<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">Uploaded to the domain documents folder and invoked via browser over the net<\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><a href=\"https:\/\/composers-inside-electronics.net\/documents\/convolver.html\">https:\/\/composers-inside-electronics.net\/documents\/convolver.html<\/a><\/p>\n\n\n\n<p class=\"wp-block-paragraph\"><\/p>\n\n\n\n<p class=\"wp-block-paragraph\">Static snapshot<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"605\" src=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-content\/uploads\/2026\/04\/image-2-1024x605.png\" alt=\"\" class=\"wp-image-5956\" srcset=\"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-content\/uploads\/2026\/04\/image-2-1024x605.png 1024w, https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-content\/uploads\/2026\/04\/image-2-300x177.png 300w, https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-content\/uploads\/2026\/04\/image-2-768x454.png 768w, https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-content\/uploads\/2026\/04\/image-2.png 1194w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n\n<p class=\"wp-block-paragraph\">and as live iframe &#8230; just click  &#8220;Play with Effect&#8221; button<\/p>\n\n\n\n<iframe loading=\"lazy\" src=\"https:\/\/composers-inside-electronics.net\/documents\/convolver.html\" title=\"Convolver Example\" width=\"500\" height=\"300\"><\/iframe>\n\n\n\n\n<p class=\"wp-block-paragraph\"><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Initial version From Google AI Mode To create a web page that allows users to select an audio clip and apply different impulse convolutions (reverb [&#8230;]<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"h5ap_radio_sources":[],"footnotes":""},"categories":[5],"tags":[403,365],"class_list":["post-5937","post","type-post","status-publish","format-standard","hentry","category-technical","tag-ai","tag-js"],"post_type":"post","author_name":"Philip Edelstein","_links":{"self":[{"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/posts\/5937","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/comments?post=5937"}],"version-history":[{"count":4,"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/posts\/5937\/revisions"}],"predecessor-version":[{"id":5959,"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/posts\/5937\/revisions\/5959"}],"wp:attachment":[{"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/media?parent=5937"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/categories?post=5937"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/composers-inside-electronics.net\/cie-wp20\/wp-json\/wp\/v2\/tags?post=5937"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}