<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:"Trebuchet MS";
        panose-1:2 11 6 3 2 2 2 2 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:70.85pt 70.85pt 2.0cm 70.85pt;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="DE-CH" link="blue" vlink="purple" style="word-wrap:break-word">
<div class="WordSection1">
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A;mso-fareast-language:EN-US">Dear Roman<br>
<br>
A static Volume setting is absolutely fine for us. We don't need dynamic changes at the moment.<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A;mso-fareast-language:EN-US">Thank you for the info's below. Very useful.<br>
<br>
We will read the documentation concerning … </span><span lang="EN-US">custom HTTP headers per mount point<br>
<br>
Sincerely,<br>
Patrick<br>
</span><span lang="EN-US" style="mso-fareast-language:EN-US"><br>
<br>
<br>
<o:p></o:p></span></p>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="DE">Von:</span></b><span lang="DE"> Roman Gorshunov <paye600@gmail.com>
<br>
<b>Gesendet:</b> Donnerstag, 25. August 2022 16:47<br>
<b>An:</b> Schneider Patrick, B2C-TSP-ITE <Patrick.Schneider1@swisscom.com><br>
<b>Cc:</b> icecast-dev@xiph.org<br>
<b>Betreff:</b> Re: [Icecast-dev] Radio Loudness<o:p></o:p></span></p>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<p class="MsoNormal">Dear Patrick,<o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">> We saw that the following commands are coming from the Backend IceCast Proxy to the Android STB<o:p></o:p></p>
</div>
<p class="MsoNormal">Icecast does not explicitly send any commands to its clients (players). It simply pushes audio streams and a little bit of metadata (title, artist, bitrate, etc.) over HTTP.<o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">HTTP protocol and Icecast do allow embedding arbitrary HTTP protocol headers [0] and send them to the client, and it would be up to the client to interpret them. However, these headers are rather static, and can not be changed dynamically
 on the fly. If your media sources require different but static adjustment of loudness (e.g. "Radio 1" always needs "+10" adjustment, and "radio 2" always nesds "-5" adjustment), then you can set it in your custom HTTP headers per mount point, and process those
 settings in your client (ExoPlayer in STB?) to change volume. With a bit of software development you could make it possible to adjust HTTP headers dynamically [1]. To do so you would need to continuously monitor loudness of source media streams and send metadata
 update commands to the Icecast server.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Another possible solution would be to add a software between your original media sources (radio stations) and Icecast, which will normalize loudness and then push modified audio to Icecast as a media source. Some possible media source clients
 are listed [2] on Icecast web site.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">[0] - <a href="https://eur03.safelinks.protection.outlook.com/?url=https%3A%2F%2Ficecast.org%2Fdocs%2Ficecast-2.4.1%2Fconfig-file.html%23mountsettings&data=05%7C01%7CPatrick.Schneider1%40swisscom.com%7C4ce28db658b04d62ef0708da86a8bf46%7C364e5b87c1c7420d9beec35d19b557a1%7C0%7C0%7C637970356562664425%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=Mak1hdLc1zFCuw1EG8rsnu%2FwDHXMFW31SJ21PMC04Dc%3D&reserved=0">https://icecast.org/docs/icecast-2.4.1/config-file.html#mountsettings</a>
 , look for <http-headers> description<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">[1] - in a way similar to stream Metadata updates <a href="https://eur03.safelinks.protection.outlook.com/?url=https%3A%2F%2Ficecast.org%2Fdocs%2Ficecast-2.4.1%2Fadmin-interface.html&data=05%7C01%7CPatrick.Schneider1%40swisscom.com%7C4ce28db658b04d62ef0708da86a8bf46%7C364e5b87c1c7420d9beec35d19b557a1%7C0%7C0%7C637970356562664425%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=vBTtJo0YPL93iwQUg1dw9nvTWuIv2Q9xdBzVq9jBCXw%3D&reserved=0">
https://icecast.org/docs/icecast-2.4.1/admin-interface.html</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">[2] - <a href="https://eur03.safelinks.protection.outlook.com/?url=https%3A%2F%2Ficecast.org%2Fapps%2F&data=05%7C01%7CPatrick.Schneider1%40swisscom.com%7C4ce28db658b04d62ef0708da86a8bf46%7C364e5b87c1c7420d9beec35d19b557a1%7C0%7C0%7C637970356562664425%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=Hoopy0CNXXvvBg2WagZagJFR2Vqj5Tke2GcE%2BcmDe8c%3D&reserved=0">https://icecast.org/apps/</a><o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Best regards,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">Roman Gorshunov<o:p></o:p></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<div>
<p class="MsoNormal">On Thu, 25 Aug 2022 at 12:48, <<a href="mailto:Patrick.Schneider1@swisscom.com">Patrick.Schneider1@swisscom.com</a>> wrote:<o:p></o:p></p>
</div>
<blockquote style="border:none;border-left:solid #CCCCCC 1.0pt;padding:0cm 0cm 0cm 6.0pt;margin-left:4.8pt;margin-right:0cm">
<div>
<div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A">Dear Roman<br>
<br>
Thank you for your answer.<br>
<br>
We as Swisscom Switzerland are in a difficult situation. We have around 1'000 Live / Replay TV Channels and 500 Radio Channels on our Platform.<br>
For Live TV we could manage the Loudness in the Transcoder/Encoding Settings. We were able to measure and align all Loudness differences and adjust to -23dB.<br>
Zapping from one TV Channel to another makes no audible difference anymore.<br>
<br>
The Problem is the change from Live TV to Radio on our Android Set-Top-Box.<br>
We are looking for a solution to align the Radio Loudness over the 500 Radio Channels.<br>
<br>
So you don't see any possibility to send an ExoPlayer message (like a Metadata) to the Player?<br>
<br>
We saw that the following commands are coming from the Backend IceCast Proxy to the Android STB:</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A"> </span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A">tvlib.ExoRadioPlayer: onPlaybackStateChanged(state=Idle)</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A">tvlib.ExoRadioPlayer: onIsLoadingChanged(isLoading=false)</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;margin-bottom:12.0pt"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A;background:yellow">tvlib.ExoRadioPlayer: onPlaybackStateChanged(state=Buffering)</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;margin-bottom:12.0pt"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A">Why not adding a ExoPlayer Volume Parameter within the Radio Channel start<br>
For example …<br>
</span><span lang="EN-US" style="font-size:10.0pt;font-family:"Courier New"">exoPlayer.sendMessage(audioRenderer, MediaCodecAudioTrackRenderer.MSG_SET_VOLUME,
<span style="color:black;background:yellow">0.9f</span>);</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;margin-bottom:12.0pt"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A"><br>
A static setting on the ExoPlayer in the client is not an option, because the Player is also used by other applications.<br>
Changing Volume in Set-top-box will affect all applications. <br>
<br>
Sincerely,<br>
Patrick</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span lang="EN-US"> </span><o:p></o:p></p>
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><b><span lang="DE">Von:</span></b><span lang="DE"> Roman Gorshunov <<a href="mailto:paye600@gmail.com" target="_blank">paye600@gmail.com</a>>
<br>
<b>Gesendet:</b> Mittwoch, 24. August 2022 19:18<br>
<b>An:</b> Schneider Patrick, B2C-TSP-ITE <<a href="mailto:Patrick.Schneider1@swisscom.com" target="_blank">Patrick.Schneider1@swisscom.com</a>><br>
<b>Cc:</b> <a href="mailto:icecast-dev@xiph.org" target="_blank">icecast-dev@xiph.org</a><br>
<b>Betreff:</b> Re: [Icecast-dev] Radio Loudness</span><o:p></o:p></p>
</div>
</div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Hello Patrick,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">It’s not really a media streaming server’s (Icecast) job to alter the volume. Volume is set either by the media source or in player.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">In addition to that, media streaming server does not allow clients (players) to control media source (e.g. change volume or skip tracks).<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">I might misunderstood your question though.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"> <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Best regards,<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">Roman Gorshunov<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;margin-bottom:12.0pt"><o:p> </o:p></p>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<p class="MsoNormal" style="mso-margin-top-alt:auto;margin-bottom:12.0pt">On 24 Aug 2022, at 11:11,
<a href="mailto:Patrick.Schneider1@swisscom.com" target="_blank">Patrick.Schneider1@swisscom.com</a> wrote:<o:p></o:p></p>
</blockquote>
</div>
<blockquote style="margin-top:5.0pt;margin-bottom:5.0pt">
<div>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">
<o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto"><span lang="EN-US" style="color:black">Dear All<br>
<br>
We are looking for a solution to send a volume parameter to our ExoPlayer during the icecast streaming initialization phase.<br>
Something like this …<br>
</span><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif"><br>
</span><span lang="EN-US" style="font-size:10.0pt;font-family:"Courier New"">Volume example:<br>
        exoPlayer.sendMessage(audioRenderer, MediaCodecAudioTrackRenderer.MSG_SET_VOLUME,
<span style="color:black;background:yellow">0.9f</span>);</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;margin-bottom:12.0pt"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:black"><br>
Is there a way to set the icecast egress streaming with an ExoPlayer default Volume?<br>
<br>
Sincerely,<br>
Patrick<br>
<br>
</span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;margin-bottom:12.0pt"><span lang="EN-US" style="font-size:10.0pt;font-family:"Trebuchet MS",sans-serif;color:#44546A"> </span><o:p></o:p></p>
<p class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto">_______________________________________________<br>
Icecast-dev mailing list<br>
<a href="mailto:Icecast-dev@xiph.org" target="_blank">Icecast-dev@xiph.org</a><br>
<a href="https://eur03.safelinks.protection.outlook.com/?url=http%3A%2F%2Flists.xiph.org%2Fmailman%2Flistinfo%2Ficecast-dev&data=05%7C01%7CPatrick.Schneider1%40swisscom.com%7C4ce28db658b04d62ef0708da86a8bf46%7C364e5b87c1c7420d9beec35d19b557a1%7C0%7C0%7C637970356562664425%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=wRtqzrw8Oll1vtSs0WQGIJZPY53mLEN5JN5Kv4UVl2g%3D&reserved=0" target="_blank">http://lists.xiph.org/mailman/listinfo/icecast-dev</a><o:p></o:p></p>
</div>
</blockquote>
</div>
</div>
</div>
</blockquote>
</div>
</div>
</body>
</html>