Recherche avancée

Médias (1)

Mot : - Tags -/illustrator

Autres articles (75)

  • Personnaliser en ajoutant son logo, sa bannière ou son image de fond

    5 septembre 2013, par

    Certains thèmes prennent en compte trois éléments de personnalisation : l’ajout d’un logo ; l’ajout d’une bannière l’ajout d’une image de fond ;

  • Ecrire une actualité

    21 juin 2013, par

    Présentez les changements dans votre MédiaSPIP ou les actualités de vos projets sur votre MédiaSPIP grâce à la rubrique actualités.
    Dans le thème par défaut spipeo de MédiaSPIP, les actualités sont affichées en bas de la page principale sous les éditoriaux.
    Vous pouvez personnaliser le formulaire de création d’une actualité.
    Formulaire de création d’une actualité Dans le cas d’un document de type actualité, les champs proposés par défaut sont : Date de publication ( personnaliser la date de publication ) (...)

  • Les vidéos

    21 avril 2011, par

    Comme les documents de type "audio", Mediaspip affiche dans la mesure du possible les vidéos grâce à la balise html5 .
    Un des inconvénients de cette balise est qu’elle n’est pas reconnue correctement par certains navigateurs (Internet Explorer pour ne pas le nommer) et que chaque navigateur ne gère en natif que certains formats de vidéos.
    Son avantage principal quant à lui est de bénéficier de la prise en charge native de vidéos dans les navigateur et donc de se passer de l’utilisation de Flash et (...)

Sur d’autres sites (10034)

  • Increasing Website Traffic : 11 Tips To Attract Visitors

    25 août 2023, par Erin — Analytics Tips, Marketing

    For your website and business to succeed, you need to focus on building traffic.

    However, you aren’t the only one with that goal in mind.

    There are millions of other websites trying to increase their traffic as well. With that much competition, it’s important to make sure your website stands out. Accomplishing that can require a great deal of strategy.

    We’ve compiled a list of tips to help you develop a solid plan for increasing website traffic, to expand your reach, grow your audience and boost customer engagement levels — creating more opportunities for your business.Using these tips, more visitors will find their way to your website — meaning more customers for your business.

    Why is website traffic important ?

    Website traffic is essentially the number of people visiting your website. When someone lands on your site, they’re considered a visitor and increase your website traffic. 

    When your website traffic is high, you’ll get more clicks, customer interactions and brand engagement. As a result, search engines will have a positive impression of your website and send more people there, meaning even more people will see your content and have the opportunity to buy your product.

    When using a website for your business or any other venture, tracking your website traffic using a web analytics solution like Matomo is critical.

    A screenshot of Matomo's Visits Dashboard

    With over 200 million actively maintained and visited websites in 2023, it’s important to make sure yours stands out if you want to increase your website traffic and grow your online presence. 

    11 tips for increasing website traffic

    Here are 11 tips to increase your organic traffic and elevate your business.

    1. Perfect your SEO

    Optimising your website to show up in search engine results shouldn’t be overlooked, as 63% of consumers start researching a product by using a search engine. Search engine optimisation, or SEO, increases the visibility and discoverability of your website on search engine results pages (SERPs). SEO targets organic searches, which means it doesn’t add to social media traffic, direct traffic or referrals, and it isn’t paid traffic.

    SEO is number one on this list for a reason — most of these tips will directly, or indirectly, improve your SEO efforts. 

    Steps to improve your search engine optimisation can include :

    • Using relevant keywords that are incorporated naturally throughout your content
    • Using a web analytics tool like Matomo, with its search keyword feature, to gain insights and identify opportunities for improvement
    • Using descriptive meta titles and meta descriptions
    • Link to your own content internally with descriptive anchor tags, and make sure unused pages are removed 
    • Keeping your target audience in mind and marketing your content toward them
    • Making sure your website’s structure is optimised to be mobile-friendly, fast and responsive — such as with Matomo’s SEO Web Vitals feature, which monitors key metrics like your website’s page speed and loading performance, pivotal for optimising search engine results

    2. Research the competition

    It’s important to remember that while your business might be unique, it’s likely not the only one in its field. Thousands of other websites from other companies are also looking to improve their website traffic and increase sales, and you have to outcompete them.

    Looking at what your competitors are doing is vital from a strategic perspective. You can see what their content looks like, how they’re framing their specific use cases and what target audience they’re marketing toward.

    Knowing what your competitors are doing can help you find ways to improve your content and make it unique. Are your competitors missing a specific use case or neglecting a particular audience ? Fill in their content gaps on your website, and pick up the traffic they’re missing.

    3. Create high-quality, evergreen content

    If your content is high-quality, visitors will read more of it and stay longer on your site. This obviously increases the likelihood they will purchase your product or service, and it tells search engines that your website is a good answer for a search query.

    High-quality content will also be shared more often, leading to even more website traffic. You should aim to develop content that doesn’t lose relevance over time (aka “evergreen content”). If you include time-sensitive data, statistics or content in your website, blog posts or articles, it’ll be relevant only around that time frame. 

    While this month’s viral content is highly popular, it likely won’t be relevant in a few months. Instead, if you ensure your content is evergreen, it will continue to get engagement long after it’s published.

    4. Implement creative visuals

    It’s important to have engaging, fun and interactive media on your website to keep visitors on your site longer. Like good content, interesting visuals (and the resulting longer visits) can translate to more purchases (and favourable assessments by search engines).

    A screenshot of Matomo's Media Dashboard

    Media can take the form of videos, infographics, images or web graphics. 

    With Matomo’s Media Analytics feature, you can automatically gain even deeper insights into how your visitors engage with your media content, enhancing your understanding of their preferences and behaviours.

    If you have interesting, captivating visuals, visitors will be more likely to stay on your website longer and see what you have to offer. Without captivating visuals to break up walls of text, you’ll likely find visitors will tend to leave your site in favour of something more engaging.

    Just make sure you design your visuals with your target audience in mind. Flashy, fun graphics might not be a good fit for a professional audience, but they’re great for younger audiences. If you get your audience correct, they may also share the images with others. Depending on your business, that might be a useful infographic shared across LinkedIn, or a picture of a clever use case shared on Pinterest. 

    As a bonus, if other companies use your graphics on their websites, that earns you some backlinks — more on those in a bit.

    5. Create a comprehensive knowledge base

    Having a knowledge base is critical to making sure your service or product is well understood and well documented, especially in the tech industry. If a visitor or potential customer is interested in your product or service, they need to know exactly what it will do for them and that they have a good foundation of support in case they need help. A knowledge base is also a good place for internal links (more on those in a bit).

    Visitors can also use your knowledge base as a source of information, and if they cite you as a source, that’ll lead right back to more website traffic for you (see our backlinks section for more about this). If your website is a good source of information, visitors will come back to it again and again.

    6. Use social media often and consistently

    Digital marketing nowadays heavily relies on social media platforms. Having an online presence no longer means just having a website — if you’re not using social media sites, you’re missing out on a huge portion of potential visitors and customers.

    A strong social media presence with profiles on platforms like Facebook, X (formerly Twitter), Instagram or LinkedIn can be invaluable for increasing your website traffic. Visitors to your social media profiles will click on regularly shared content, read your blog posts and possibly become customers.

    Participating in relevant communities and networking with other companies in groups in your industry can also be invaluable. If you participate in online communities and forums for your niche, you can offer insight, answer questions and plug your website. All of this will increase your clicks, which will increase your website traffic.

    If you’ve managed to build your own community on social media, make sure to keep them engaged ! Implementing your own forum, hosting live chats and Q&As, offering helpful and engaging content will make sure visitors keep coming back and spreading the word. 

    7. Use email marketing or newsletters

    Having an email list and sending marketing emails or newsletters is a great way to increase website traffic. You can offer exclusive content, and promise discounts or resources to your subscribers for when they return to your website. This will help keep your loyal audience engaged, entice new customers to subscribe to your newsletter, give you a chance to upsell to people who have already expressed an interest in your product and potentially convert curious subscribers into customers.

    8. Make sure your content can earn backlinks

    A backlink is when a website links to a different website — ideally using relevant anchor text — and it’s an effective strategy for increasing referral traffic, that is, visitors who get to your website via a link on another website. The more backlinks you have, the more your referral traffic will increase. Social share buttons make it easy for people to cite you on social platforms, too. 

    We’ve already talked about making expert content that’s link-worthy, but also make sure that you’re creating linkable assets (like those interesting visuals mentioned earlier), building relationships with other sites that will link to you (like by inviting an expert or influencer to write on your page and promote it from their platform, or by writing your own guest content for their sites) and sharing your own content. All of this can help increase your referral traffic, particularly when you’re linked from websites with a higher domain authority than you have.

    You can also make sure your website is listed in online directories. Some sites will do interviews and roundups, as well — these are great opportunities to increase your backlinks.

    9. Optimise your CTR

    Click-through rate, or CTR, is the percentage of users who click on specific links to your website. A high CTR means your visitors are following a link — whether in an advertisement, a search result or a social media post — and a low CTR means they’re passing it by. Optimising your CTR can greatly improve your website traffic.

    To improve CTR, identify successful elements such as copy, imagery, and offers in your ads, enabling you to amplify effective elements and minimise less impactful ones.

    10. Ensure your website is responsive and mobile-friendly

    If a visitor is frustrated by your site being slow, laggy, clunky or not mobile-friendly, they won’t stay long. That doesn’t look good to search engines if that’s how your visitors got there. Your website needs to be clean, responsive, user-friendly and accessible.

    If your website is slow, try increasing your website’s performance by :

    • Optimising images : Reduce the size of images and compress them for faster load times. Opt for JPEG format for photos and PNG format for graphics. 
    • Limit the use of plugins : If you are using a CMS like WordPress, consider removing plugins that are unnecessary or not essential.
    • Embrace lazy loading : To further enhance site speed and reduce initial load times, set up your site to load images and content only as visitors scroll down. Prioritising the content and images at the top of the page makes the site feel faster. Some CMS platforms will offer this option, but others may require a bit of coding to set this up. 

    Many people rely on their phones to research services or products, especially if they’re doing a quick search. Make sure your website is friendly to mobile users. It should scale vertically and scroll smoothly so users aren’t frustrated when using your site. They should be able to find the info they need immediately without any technical issues.

    11. Track your website’s metrics

    As you test out each of these strategies to increase your web traffic, don’t forget to closely analyse the performance of your site. To truly understand the impact of your efforts, you’ll need a reliable web analytics solution. Think of a dependable web analytics solution as your website’s GPS. Without it, you’d be lost, unsure of your direction and missing out on valuable insights to steer your growth.

    Matomo is a powerful web analytics tool that can help you do just that by providing information on your site visitors and campaign performance, complemented by an array of behavioural analytics features that delve into user interactions. Among these, our heatmap feature stands out, enabling greater insights into user interactions and optimisation of your site’s effectiveness.

    Screenshot of Matomo heatmap feature

    Google Analytics is another powerful analytics option, though it has challenges with data accuracy ; there are multiple other web analytics solutions as well.

    Regardless of what web analytics solution you choose, the process of analysing your website metrics is incredibly important for identifying areas of improvement to increase website traffic.

    Increasing your web traffic is a process

    Increasing website traffic isn’t something you accomplish overnight. It’s a comprehensive, ongoing endeavour that requires constant analysis and fine-tuning. 

    By applying these tips to create consistent, high-quality content that gets spotlighted on search engines, shared on social media and returned to again and again, you’ll see a steady stream of increased traffic. 

    With Matomo, you can understand your visitor behaviour to see what works and what doesn’t as you work to increase your website traffic. Get your free 21-day trial now. No credit card required.

  • how to extract audio from video using ffmpeg c++

    29 septembre 2020, par daenerys

    I am trying to write c++ code on how to extract audio from mp4 format file. I have compiled the examples in ffmpeg library and tried to run the demuxing_decoding.c file. The problem is that on running the code, it starts to decode way more than the actual file size and decodes wrong codec format (the decoded files cant be run).

    



    here is the demuxing_decoding.c that I am trying to run :

    



    #include &#xA;&#xA;#include <libavutil></libavutil>opt.h>&#xA;#include <libavcodec></libavcodec>avcodec.h>&#xA;#include <libavutil></libavutil>channel_layout.h>&#xA;#include <libavutil></libavutil>common.h>&#xA;#include <libavutil></libavutil>imgutils.h>&#xA;#include <libavutil></libavutil>mathematics.h>&#xA;#include <libavutil></libavutil>samplefmt.h>&#xA;&#xA;#define INBUF_SIZE 4096&#xA;#define AUDIO_INBUF_SIZE 20480&#xA;#define AUDIO_REFILL_THRESH 4096&#xA;&#xA;/* check that a given sample format is supported by the encoder */&#xA;static int check_sample_fmt(AVCodec *codec, enum AVSampleFormat sample_fmt)&#xA;{&#xA;    const enum AVSampleFormat *p = codec->sample_fmts;&#xA;&#xA;    while (*p != AV_SAMPLE_FMT_NONE) {&#xA;        if (*p == sample_fmt)&#xA;            return 1;&#xA;        p&#x2B;&#x2B;;&#xA;    }&#xA;    return 0;&#xA;}&#xA;&#xA;/* just pick the highest supported samplerate */&#xA;static int select_sample_rate(AVCodec *codec)&#xA;{&#xA;    const int *p;&#xA;    int best_samplerate = 0;&#xA;&#xA;    if (!codec->supported_samplerates)&#xA;        return 44100;&#xA;&#xA;    p = codec->supported_samplerates;&#xA;    while (*p) {&#xA;        best_samplerate = FFMAX(*p, best_samplerate);&#xA;        p&#x2B;&#x2B;;&#xA;    }&#xA;    return best_samplerate;&#xA;}&#xA;&#xA;/* select layout with the highest channel count */&#xA;static int select_channel_layout(AVCodec *codec)&#xA;{&#xA;    const uint64_t *p;&#xA;    uint64_t best_ch_layout = 0;&#xA;    int best_nb_channels   = 0;&#xA;&#xA;    if (!codec->channel_layouts)&#xA;        return AV_CH_LAYOUT_STEREO;&#xA;&#xA;    p = codec->channel_layouts;&#xA;    while (*p) {&#xA;        int nb_channels = av_get_channel_layout_nb_channels(*p);&#xA;&#xA;        if (nb_channels > best_nb_channels) {&#xA;            best_ch_layout    = *p;&#xA;            best_nb_channels = nb_channels;&#xA;        }&#xA;        p&#x2B;&#x2B;;&#xA;    }&#xA;    return best_ch_layout;&#xA;}&#xA;&#xA;/*&#xA; * Audio encoding example&#xA; */&#xA;static void audio_encode_example(const char *filename)&#xA;{&#xA;    AVCodec *codec;&#xA;    AVCodecContext *c= NULL;&#xA;    AVFrame *frame;&#xA;    AVPacket pkt;&#xA;    int i, j, k, ret, got_output;&#xA;    int buffer_size;&#xA;    FILE *f;&#xA;    uint16_t *samples;&#xA;    float t, tincr;&#xA;&#xA;    printf("Encode audio file %s\n", filename);&#xA;&#xA;    /* find the MP2 encoder */&#xA;    codec = avcodec_find_encoder(AV_CODEC_ID_MP2);&#xA;    if (!codec) {&#xA;        fprintf(stderr, "Codec not found\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    c = avcodec_alloc_context3(codec);&#xA;    if (!c) {&#xA;        fprintf(stderr, "Could not allocate audio codec context\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    /* put sample parameters */&#xA;    c->bit_rate = 64000;&#xA;&#xA;    /* check that the encoder supports s16 pcm input */&#xA;    c->sample_fmt = AV_SAMPLE_FMT_S16;&#xA;    if (!check_sample_fmt(codec, c->sample_fmt)) {&#xA;        fprintf(stderr, "Encoder does not support sample format %s",&#xA;                av_get_sample_fmt_name(c->sample_fmt));&#xA;        exit(1);&#xA;    }&#xA;&#xA;    /* select other audio parameters supported by the encoder */&#xA;    c->sample_rate    = select_sample_rate(codec);&#xA;    c->channel_layout = select_channel_layout(codec);&#xA;    c->channels       = av_get_channel_layout_nb_channels(c->channel_layout);&#xA;&#xA;    /* open it */&#xA;    if (avcodec_open2(c, codec, NULL) &lt; 0) {&#xA;        fprintf(stderr, "Could not open codec\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    f = fopen(filename, "wb");&#xA;    if (!f) {&#xA;        fprintf(stderr, "Could not open %s\n", filename);&#xA;        exit(1);&#xA;    }&#xA;&#xA;    /* frame containing input raw audio */&#xA;    frame = av_frame_alloc();&#xA;    if (!frame) {&#xA;        fprintf(stderr, "Could not allocate audio frame\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    frame->nb_samples     = c->frame_size;&#xA;    frame->format         = c->sample_fmt;&#xA;    frame->channel_layout = c->channel_layout;&#xA;&#xA;    /* the codec gives us the frame size, in samples,&#xA;     * we calculate the size of the samples buffer in bytes */&#xA;    buffer_size = av_samples_get_buffer_size(NULL, c->channels, c->frame_size,&#xA;                                             c->sample_fmt, 0);&#xA;    if (buffer_size &lt; 0) {&#xA;        fprintf(stderr, "Could not get sample buffer size\n");&#xA;        exit(1);&#xA;    }&#xA;    samples = av_malloc(buffer_size);&#xA;    if (!samples) {&#xA;        fprintf(stderr, "Could not allocate %d bytes for samples buffer\n",&#xA;                buffer_size);&#xA;        exit(1);&#xA;    }&#xA;    /* setup the data pointers in the AVFrame */&#xA;    ret = avcodec_fill_audio_frame(frame, c->channels, c->sample_fmt,&#xA;                                   (const uint8_t*)samples, buffer_size, 0);&#xA;    if (ret &lt; 0) {&#xA;        fprintf(stderr, "Could not setup audio frame\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    /* encode a single tone sound */&#xA;    t = 0;&#xA;    tincr = 2 * M_PI * 440.0 / c->sample_rate;&#xA;    for (i = 0; i &lt; 200; i&#x2B;&#x2B;) {&#xA;        av_init_packet(&amp;pkt);&#xA;        pkt.data = NULL; // packet data will be allocated by the encoder&#xA;        pkt.size = 0;&#xA;&#xA;        for (j = 0; j &lt; c->frame_size; j&#x2B;&#x2B;) {&#xA;            samples[2*j] = (int)(sin(t) * 10000);&#xA;&#xA;            for (k = 1; k &lt; c->channels; k&#x2B;&#x2B;)&#xA;                samples[2*j &#x2B; k] = samples[2*j];&#xA;            t &#x2B;= tincr;&#xA;        }&#xA;        /* encode the samples */&#xA;        ret = avcodec_encode_audio2(c, &amp;pkt, frame, &amp;got_output);&#xA;        if (ret &lt; 0) {&#xA;            fprintf(stderr, "Error encoding audio frame\n");&#xA;            exit(1);&#xA;        }&#xA;        if (got_output) {&#xA;            fwrite(pkt.data, 1, pkt.size, f);&#xA;            av_free_packet(&amp;pkt);&#xA;        }&#xA;    }&#xA;&#xA;    /* get the delayed frames */&#xA;    for (got_output = 1; got_output; i&#x2B;&#x2B;) {&#xA;        ret = avcodec_encode_audio2(c, &amp;pkt, NULL, &amp;got_output);&#xA;        if (ret &lt; 0) {&#xA;            fprintf(stderr, "Error encoding frame\n");&#xA;            exit(1);&#xA;        }&#xA;&#xA;        if (got_output) {&#xA;            fwrite(pkt.data, 1, pkt.size, f);&#xA;            av_free_packet(&amp;pkt);&#xA;        }&#xA;    }&#xA;    fclose(f);&#xA;&#xA;    av_freep(&amp;samples);&#xA;    av_frame_free(&amp;frame);&#xA;    avcodec_close(c);&#xA;    av_free(c);&#xA;}&#xA;&#xA;/*&#xA; * Audio decoding.&#xA; */&#xA;static void audio_decode_example(const char *outfilename, const char *filename)&#xA;{&#xA;    AVCodec *codec;&#xA;    AVCodecContext *c= NULL;&#xA;    int len;&#xA;    FILE *f, *outfile;&#xA;    uint8_t inbuf[AUDIO_INBUF_SIZE &#x2B; AV_INPUT_BUFFER_PADDING_SIZE];&#xA;    AVPacket avpkt;&#xA;    AVFrame *decoded_frame = NULL;&#xA;&#xA;    av_init_packet(&amp;avpkt);&#xA;&#xA;    printf("Decode audio file %s to %s\n", filename, outfilename);&#xA;&#xA;    /* find the mpeg audio decoder */&#xA;    codec = avcodec_find_decoder(AV_CODEC_ID_MP2);&#xA;    if (!codec) {&#xA;        fprintf(stderr, "Codec not found\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    c = avcodec_alloc_context3(codec);&#xA;    if (!c) {&#xA;        fprintf(stderr, "Could not allocate audio codec context\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    /* open it */&#xA;    if (avcodec_open2(c, codec, NULL) &lt; 0) {&#xA;        fprintf(stderr, "Could not open codec\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    f = fopen(filename, "rb");&#xA;    if (!f) {&#xA;        fprintf(stderr, "Could not open %s\n", filename);&#xA;        exit(1);&#xA;    }&#xA;    outfile = fopen(outfilename, "wb");&#xA;    if (!outfile) {&#xA;        av_free(c);&#xA;        exit(1);&#xA;    }&#xA;&#xA;    /* decode until eof */&#xA;    avpkt.data = inbuf;&#xA;    avpkt.size = fread(inbuf, 1, AUDIO_INBUF_SIZE, f);&#xA;&#xA;    while (avpkt.size > 0) {&#xA;        int i, ch;&#xA;        int got_frame = 0;&#xA;&#xA;        if (!decoded_frame) {&#xA;            if (!(decoded_frame = av_frame_alloc())) {&#xA;                fprintf(stderr, "Could not allocate audio frame\n");&#xA;                exit(1);&#xA;            }&#xA;        }&#xA;&#xA;        len = avcodec_decode_audio4(c, decoded_frame, &amp;got_frame, &amp;avpkt);&#xA;        if (len &lt; 0) {&#xA;            fprintf(stderr, "Error while decoding\n");&#xA;            exit(1);&#xA;        }&#xA;        if (got_frame) {&#xA;            /* if a frame has been decoded, output it */&#xA;            int data_size = av_get_bytes_per_sample(c->sample_fmt);&#xA;            if (data_size &lt; 0) {&#xA;                /* This should not occur, checking just for paranoia */&#xA;                fprintf(stderr, "Failed to calculate data size\n");&#xA;                exit(1);&#xA;            }&#xA;            for (i=0; inb_samples; i&#x2B;&#x2B;)&#xA;                for (ch=0; chchannels; ch&#x2B;&#x2B;)&#xA;                    fwrite(decoded_frame->data[ch] &#x2B; data_size*i, 1, data_size, outfile);&#xA;        }&#xA;        avpkt.size -= len;&#xA;        avpkt.data &#x2B;= len;&#xA;        avpkt.dts =&#xA;        avpkt.pts = AV_NOPTS_VALUE;&#xA;        if (avpkt.size &lt; AUDIO_REFILL_THRESH) {&#xA;            /* Refill the input buffer, to avoid trying to decode&#xA;             * incomplete frames. Instead of this, one could also use&#xA;             * a parser, or use a proper container format through&#xA;             * libavformat. */&#xA;            memmove(inbuf, avpkt.data, avpkt.size);&#xA;            avpkt.data = inbuf;&#xA;            len = fread(avpkt.data &#x2B; avpkt.size, 1,&#xA;                        AUDIO_INBUF_SIZE - avpkt.size, f);&#xA;            if (len > 0)&#xA;                avpkt.size &#x2B;= len;&#xA;        }&#xA;    }&#xA;&#xA;    fclose(outfile);&#xA;    fclose(f);&#xA;&#xA;    avcodec_close(c);&#xA;    av_free(c);&#xA;    av_frame_free(&amp;decoded_frame);&#xA;}&#xA;&#xA;/*&#xA; * Video encoding example&#xA; */&#xA;static void video_encode_example(const char *filename, int codec_id)&#xA;{&#xA;    AVCodec *codec;&#xA;    AVCodecContext *c= NULL;&#xA;    int i, ret, x, y, got_output;&#xA;    FILE *f;&#xA;    AVFrame *frame;&#xA;    AVPacket pkt;&#xA;    uint8_t endcode[] = { 0, 0, 1, 0xb7 };&#xA;&#xA;    printf("Encode video file %s\n", filename);&#xA;&#xA;    /* find the mpeg1 video encoder */&#xA;    codec = avcodec_find_encoder(codec_id);&#xA;    if (!codec) {&#xA;        fprintf(stderr, "Codec not found\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    c = avcodec_alloc_context3(codec);&#xA;    if (!c) {&#xA;        fprintf(stderr, "Could not allocate video codec context\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    /* put sample parameters */&#xA;    c->bit_rate = 400000;&#xA;    /* resolution must be a multiple of two */&#xA;    c->width = 352;&#xA;    c->height = 288;&#xA;    /* frames per second */&#xA;    c->time_base = (AVRational){1,25};&#xA;    /* emit one intra frame every ten frames&#xA;     * check frame pict_type before passing frame&#xA;     * to encoder, if frame->pict_type is AV_PICTURE_TYPE_I&#xA;     * then gop_size is ignored and the output of encoder&#xA;     * will always be I frame irrespective to gop_size&#xA;     */&#xA;    c->gop_size = 10;&#xA;    c->max_b_frames = 1;&#xA;    c->pix_fmt = AV_PIX_FMT_YUV420P;&#xA;&#xA;    if (codec_id == AV_CODEC_ID_H264)&#xA;        av_opt_set(c->priv_data, "preset", "slow", 0);&#xA;&#xA;    /* open it */&#xA;    if (avcodec_open2(c, codec, NULL) &lt; 0) {&#xA;        fprintf(stderr, "Could not open codec\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    f = fopen(filename, "wb");&#xA;    if (!f) {&#xA;        fprintf(stderr, "Could not open %s\n", filename);&#xA;        exit(1);&#xA;    }&#xA;&#xA;    frame = av_frame_alloc();&#xA;    if (!frame) {&#xA;        fprintf(stderr, "Could not allocate video frame\n");&#xA;        exit(1);&#xA;    }&#xA;    frame->format = c->pix_fmt;&#xA;    frame->width  = c->width;&#xA;    frame->height = c->height;&#xA;&#xA;    /* the image can be allocated by any means and av_image_alloc() is&#xA;     * just the most convenient way if av_malloc() is to be used */&#xA;    ret = av_image_alloc(frame->data, frame->linesize, c->width, c->height,&#xA;                         c->pix_fmt, 32);&#xA;    if (ret &lt; 0) {&#xA;        fprintf(stderr, "Could not allocate raw picture buffer\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    /* encode 1 second of video */&#xA;    for (i = 0; i &lt; 25; i&#x2B;&#x2B;) {&#xA;        av_init_packet(&amp;pkt);&#xA;        pkt.data = NULL;    // packet data will be allocated by the encoder&#xA;        pkt.size = 0;&#xA;&#xA;        fflush(stdout);&#xA;        /* prepare a dummy image */&#xA;        /* Y */&#xA;        for (y = 0; y &lt; c->height; y&#x2B;&#x2B;) {&#xA;            for (x = 0; x &lt; c->width; x&#x2B;&#x2B;) {&#xA;                frame->data[0][y * frame->linesize[0] &#x2B; x] = x &#x2B; y &#x2B; i * 3;&#xA;            }&#xA;        }&#xA;&#xA;        /* Cb and Cr */&#xA;        for (y = 0; y &lt; c->height/2; y&#x2B;&#x2B;) {&#xA;            for (x = 0; x &lt; c->width/2; x&#x2B;&#x2B;) {&#xA;                frame->data[1][y * frame->linesize[1] &#x2B; x] = 128 &#x2B; y &#x2B; i * 2;&#xA;                frame->data[2][y * frame->linesize[2] &#x2B; x] = 64 &#x2B; x &#x2B; i * 5;&#xA;            }&#xA;        }&#xA;&#xA;        frame->pts = i;&#xA;&#xA;        /* encode the image */&#xA;        ret = avcodec_encode_video2(c, &amp;pkt, frame, &amp;got_output);&#xA;        if (ret &lt; 0) {&#xA;            fprintf(stderr, "Error encoding frame\n");&#xA;            exit(1);&#xA;        }&#xA;&#xA;        if (got_output) {&#xA;            printf("Write frame %3d (size=%5d)\n", i, pkt.size);&#xA;            fwrite(pkt.data, 1, pkt.size, f);&#xA;            av_free_packet(&amp;pkt);&#xA;        }&#xA;    }&#xA;&#xA;    /* get the delayed frames */&#xA;    for (got_output = 1; got_output; i&#x2B;&#x2B;) {&#xA;        fflush(stdout);&#xA;&#xA;        ret = avcodec_encode_video2(c, &amp;pkt, NULL, &amp;got_output);&#xA;        if (ret &lt; 0) {&#xA;            fprintf(stderr, "Error encoding frame\n");&#xA;            exit(1);&#xA;        }&#xA;&#xA;        if (got_output) {&#xA;            printf("Write frame %3d (size=%5d)\n", i, pkt.size);&#xA;            fwrite(pkt.data, 1, pkt.size, f);&#xA;            av_free_packet(&amp;pkt);&#xA;        }&#xA;    }&#xA;&#xA;    /* add sequence end code to have a real mpeg file */&#xA;    fwrite(endcode, 1, sizeof(endcode), f);&#xA;    fclose(f);&#xA;&#xA;    avcodec_close(c);&#xA;    av_free(c);&#xA;    av_freep(&amp;frame->data[0]);&#xA;    av_frame_free(&amp;frame);&#xA;    printf("\n");&#xA;}&#xA;&#xA;/*&#xA; * Video decoding example&#xA; */&#xA;&#xA;static void pgm_save(unsigned char *buf, int wrap, int xsize, int ysize,&#xA;                     char *filename)&#xA;{&#xA;    FILE *f;&#xA;    int i;&#xA;&#xA;    f = fopen(filename,"w");&#xA;    fprintf(f, "P5\n%d %d\n%d\n", xsize, ysize, 255);&#xA;    for (i = 0; i &lt; ysize; i&#x2B;&#x2B;)&#xA;        fwrite(buf &#x2B; i * wrap, 1, xsize, f);&#xA;    fclose(f);&#xA;}&#xA;&#xA;static int decode_write_frame(const char *outfilename, AVCodecContext *avctx,&#xA;                              AVFrame *frame, int *frame_count, AVPacket *pkt, int last)&#xA;{&#xA;    int len, got_frame;&#xA;    char buf[1024];&#xA;&#xA;    len = avcodec_decode_video2(avctx, frame, &amp;got_frame, pkt);&#xA;    if (len &lt; 0) {&#xA;        fprintf(stderr, "Error while decoding frame %d\n", *frame_count);&#xA;        return len;&#xA;    }&#xA;    if (got_frame) {&#xA;        printf("Saving %sframe %3d\n", last ? "last " : "", *frame_count);&#xA;        fflush(stdout);&#xA;&#xA;        /* the picture is allocated by the decoder, no need to free it */&#xA;        snprintf(buf, sizeof(buf), outfilename, *frame_count);&#xA;        pgm_save(frame->data[0], frame->linesize[0],&#xA;                 frame->width, frame->height, buf);&#xA;        (*frame_count)&#x2B;&#x2B;;&#xA;    }&#xA;    if (pkt->data) {&#xA;        pkt->size -= len;&#xA;        pkt->data &#x2B;= len;&#xA;    }&#xA;    return 0;&#xA;}&#xA;&#xA;static void video_decode_example(const char *outfilename, const char *filename)&#xA;{&#xA;    AVCodec *codec;&#xA;    AVCodecContext *c= NULL;&#xA;    int frame_count;&#xA;    FILE *f;&#xA;    AVFrame *frame;&#xA;    uint8_t inbuf[INBUF_SIZE &#x2B; AV_INPUT_BUFFER_PADDING_SIZE];&#xA;    AVPacket avpkt;&#xA;&#xA;    av_init_packet(&amp;avpkt);&#xA;&#xA;    /* set end of buffer to 0 (this ensures that no overreading happens for damaged mpeg streams) */&#xA;    memset(inbuf &#x2B; INBUF_SIZE, 0, AV_INPUT_BUFFER_PADDING_SIZE);&#xA;&#xA;    printf("Decode video file %s to %s\n", filename, outfilename);&#xA;&#xA;    /* find the mpeg1 video decoder */&#xA;    codec = avcodec_find_decoder(AV_CODEC_ID_MPEG1VIDEO);&#xA;    if (!codec) {&#xA;        fprintf(stderr, "Codec not found\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    c = avcodec_alloc_context3(codec);&#xA;    if (!c) {&#xA;        fprintf(stderr, "Could not allocate video codec context\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    if (codec->capabilities &amp; AV_CODEC_CAP_TRUNCATED)&#xA;        c->flags |= AV_CODEC_FLAG_TRUNCATED; // we do not send complete frames&#xA;&#xA;    /* For some codecs, such as msmpeg4 and mpeg4, width and height&#xA;       MUST be initialized there because this information is not&#xA;       available in the bitstream. */&#xA;&#xA;    /* open it */&#xA;    if (avcodec_open2(c, codec, NULL) &lt; 0) {&#xA;        fprintf(stderr, "Could not open codec\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    f = fopen(filename, "rb");&#xA;    if (!f) {&#xA;        fprintf(stderr, "Could not open %s\n", filename);&#xA;        exit(1);&#xA;    }&#xA;&#xA;    frame = av_frame_alloc();&#xA;    if (!frame) {&#xA;        fprintf(stderr, "Could not allocate video frame\n");&#xA;        exit(1);&#xA;    }&#xA;&#xA;    frame_count = 0;&#xA;    for (;;) {&#xA;        avpkt.size = fread(inbuf, 1, INBUF_SIZE, f);&#xA;        if (avpkt.size == 0)&#xA;            break;&#xA;&#xA;        /* NOTE1: some codecs are stream based (mpegvideo, mpegaudio)&#xA;           and this is the only method to use them because you cannot&#xA;           know the compressed data size before analysing it.&#xA;&#xA;           BUT some other codecs (msmpeg4, mpeg4) are inherently frame&#xA;           based, so you must call them with all the data for one&#xA;           frame exactly. You must also initialize &#x27;width&#x27; and&#xA;           &#x27;height&#x27; before initializing them. */&#xA;&#xA;        /* NOTE2: some codecs allow the raw parameters (frame size,&#xA;           sample rate) to be changed at any frame. We handle this, so&#xA;           you should also take care of it */&#xA;&#xA;        /* here, we use a stream based decoder (mpeg1video), so we&#xA;           feed decoder and see if it could decode a frame */&#xA;        avpkt.data = inbuf;&#xA;        while (avpkt.size > 0)&#xA;            if (decode_write_frame(outfilename, c, frame, &amp;frame_count, &amp;avpkt, 0) &lt; 0)&#xA;                exit(1);&#xA;    }&#xA;&#xA;    /* some codecs, such as MPEG, transmit the I and P frame with a&#xA;       latency of one frame. You must do the following to have a&#xA;       chance to get the last frame of the video */&#xA;    avpkt.data = NULL;&#xA;    avpkt.size = 0;&#xA;    decode_write_frame(outfilename, c, frame, &amp;frame_count, &amp;avpkt, 1);&#xA;&#xA;    fclose(f);&#xA;&#xA;    avcodec_close(c);&#xA;    av_free(c);&#xA;    av_frame_free(&amp;frame);&#xA;    printf("\n");&#xA;}&#xA;&#xA;int main(int argc, char **argv)&#xA;{&#xA;    const char *output_type;&#xA;&#xA;    /* register all the codecs */&#xA;    avcodec_register_all();&#xA;&#xA;    if (argc &lt; 2) {&#xA;        printf("usage: %s output_type\n"&#xA;               "API example program to decode/encode a media stream with libavcodec.\n"&#xA;               "This program generates a synthetic stream and encodes it to a file\n"&#xA;               "named test.h264, test.mp2 or test.mpg depending on output_type.\n"&#xA;               "The encoded stream is then decoded and written to a raw data output.\n"&#xA;               "output_type must be chosen between &#x27;h264&#x27;, &#x27;mp2&#x27;, &#x27;mpg&#x27;.\n",&#xA;               argv[0]);&#xA;        return 1;&#xA;    }&#xA;    output_type = argv[1];&#xA;&#xA;    if (!strcmp(output_type, "h264")) {&#xA;        video_encode_example("test.h264", AV_CODEC_ID_H264);&#xA;    } else if (!strcmp(output_type, "mp2")) {&#xA;        audio_encode_example("test.mp2");&#xA;        audio_decode_example("test.pcm", "test.mp2");&#xA;    } else if (!strcmp(output_type, "mpg")) {&#xA;        video_encode_example("test.mpg", AV_CODEC_ID_MPEG1VIDEO);&#xA;        video_decode_example("test%02d.pgm", "test.mpg");&#xA;    } else {&#xA;        fprintf(stderr, "Invalid output type &#x27;%s&#x27;, choose between &#x27;h264&#x27;, &#x27;mp2&#x27;, or &#x27;mpg&#x27;\n",&#xA;                output_type);&#xA;        return 1;&#xA;    }&#xA;&#xA;    return 0;&#xA;}&#xA;

    &#xA;&#xA;

    What could be wrong ?&#xA;The command I used is :

    &#xA;&#xA;

    ./demuxing_decoding /home/cortana/Burn.mp4 /home/cortana/Desktop/Burn.mp4 /home/cortana/Desktop/Burn.aac&#xA;

    &#xA;

  • ffmpeg aresample has no effect while it works in ffplay

    11 novembre 2020, par Lemon Sky

    I have a .ts file which is missing frames 20 seconds into the file. I'd like to fill the missing parts with silence. This works using the following command with ffplay :

    &#xA;

    ffplay -i http://tyberis.com/KFYI-AM_2020-10-30_09-05-26.ts -af aresample=async=1

    &#xA;

    The same should work with ffmpeg but no silence is injected. Instead, the audio just continues playing. Example :

    &#xA;

    ffmpeg -i http://tyberis.com/KFYI-AM_2020-10-30_09-05-26.ts -af aresample=async=1 -f wav -acodec pcm_s16le -ac 2 - | ffplay -i -

    &#xA;

    What am I doing wrong ?

    &#xA;

    Log :

    &#xA;

    >ffmpeg -y -nostats -loglevel trace -i http://tyberis.com/KFYI-AM_2020-10-30_09-05-26.ts -af aresample=async=1 -f wav -acodec pcm_s16le -ac 2 out.wav&#xA;ffmpeg version 4.3.1-2020-11-08-full_build-www.gyan.dev Copyright (c) 2000-2020 the FFmpeg developers&#xA;  built with gcc 10.2.0 (Rev3, Built by MSYS2 project)&#xA;  configuration: --enable-gpl --enable-version3 --enable-static --disable-w32threads --disable-autodetect --enable-fontconfig --enable-iconv --enable-gnutls --enable-libxml2 --enable-gmp --enable-lzma --enable-libsnappy --enable-zlib --enable-libsrt --enable-libssh --enable-libzmq --enable-avisynth --enable-libbluray --enable-libcaca --enable-sdl2 --enable-libdav1d --enable-libzvbi --enable-librav1e --enable-libwebp --enable-libx264 --enable-libx265 --enable-libxvid --enable-libaom --enable-libopenjpeg --enable-libvpx --enable-libass --enable-frei0r --enable-libfreetype --enable-libfribidi --enable-libvidstab --enable-libvmaf --enable-libzimg --enable-amf --enable-cuda-llvm --enable-cuvid --enable-ffnvcodec --enable-nvdec --enable-nvenc --enable-d3d11va --enable-dxva2 --enable-libmfx --enable-libcdio --enable-libgme --enable-libmodplug --enable-libopenmpt --enable-libopencore-amrwb --enable-libmp3lame --enable-libshine --enable-libtheora --enable-libtwolame --enable-libvo-amrwbenc --enable-libilbc --enable-libgsm --enable-libopencore-amrnb --enable-libopus --enable-libspeex --enable-libvorbis --enable-ladspa --enable-libbs2b --enable-libflite --enable-libmysofa --enable-librubberband --enable-libsoxr --enable-chromaprint&#xA;  libavutil      56. 51.100 / 56. 51.100&#xA;  libavcodec     58. 91.100 / 58. 91.100&#xA;  libavformat    58. 45.100 / 58. 45.100&#xA;  libavdevice    58. 10.100 / 58. 10.100&#xA;  libavfilter     7. 85.100 /  7. 85.100&#xA;  libswscale      5.  7.100 /  5.  7.100&#xA;  libswresample   3.  7.100 /  3.  7.100&#xA;  libpostproc    55.  7.100 / 55.  7.100&#xA;Splitting the commandline.&#xA;Reading option &#x27;-y&#x27; ... matched as option &#x27;y&#x27; (overwrite output files) with argument &#x27;1&#x27;.&#xA;Reading option &#x27;-nostats&#x27; ... matched as option &#x27;stats&#x27; (print progress report during encoding) with argument 0.&#xA;Reading option &#x27;-loglevel&#x27; ... matched as option &#x27;loglevel&#x27; (set logging level) with argument &#x27;trace&#x27;.&#xA;Reading option &#x27;-i&#x27; ... matched as input url with argument &#x27;http://tyberis.com/KFYI-AM_2020-10-30_09-05-26.ts&#x27;.&#xA;Reading option &#x27;-af&#x27; ... matched as option &#x27;af&#x27; (set audio filters) with argument &#x27;aresample=async=1&#x27;.&#xA;Reading option &#x27;-f&#x27; ... matched as option &#x27;f&#x27; (force format) with argument &#x27;wav&#x27;.&#xA;Reading option &#x27;-acodec&#x27; ... matched as option &#x27;acodec&#x27; (force audio codec (&#x27;copy&#x27; to copy stream)) with argument &#x27;pcm_s16le&#x27;.&#xA;Reading option &#x27;-ac&#x27; ... matched as option &#x27;ac&#x27; (set number of audio channels) with argument &#x27;2&#x27;.&#xA;Reading option &#x27;out.wav&#x27; ... matched as output url.&#xA;Finished splitting the commandline.&#xA;Parsing a group of options: global .&#xA;Applying option y (overwrite output files) with argument 1.&#xA;Applying option nostats (print progress report during encoding) with argument 0.&#xA;Applying option loglevel (set logging level) with argument trace.&#xA;Successfully parsed a group of options.&#xA;Parsing a group of options: input url http://tyberis.com/KFYI-AM_2020-10-30_09-05-26.ts.&#xA;Successfully parsed a group of options.&#xA;Opening an input file: http://tyberis.com/KFYI-AM_2020-10-30_09-05-26.ts.&#xA;[NULL @ 000001d0e7bbd200] Opening &#x27;http://tyberis.com/KFYI-AM_2020-10-30_09-05-26.ts&#x27; for reading&#xA;[http @ 000001d0e7bbe2c0] Setting default whitelist &#x27;http,https,tls,rtp,tcp,udp,crypto,httpproxy,data&#x27;&#xA;[tcp @ 000001d0e7bc0d00] Original list of addresses:&#xA;[tcp @ 000001d0e7bc0d00] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7bc0d00] Interleaved list of addresses:&#xA;[tcp @ 000001d0e7bc0d00] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7bc0d00] Starting connection attempt to 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7bc0d00] Successfully connected to 144.2.127.86 port 80&#xA;[http @ 000001d0e7bbe2c0] request: GET /KFYI-AM_2020-10-30_09-05-26.ts HTTP/1.1&#xA;User-Agent: Lavf/58.45.100&#xA;Accept: */*&#xA;Range: bytes=0-&#xA;Connection: close&#xA;Host: tyberis.com&#xA;Icy-MetaData: 1&#xA;&#xA;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;HTTP/1.1 206 Partial Content&#x27;&#xA;[http @ 000001d0e7bbe2c0] http_code=206&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Type: video/vnd.dlna.mpeg-tts&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Last-Modified: Tue, 10 Nov 2020 19:12:18 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Accept-Ranges: bytes&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;ETag: "7c6a9e6895b7d61:0"&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Server: Microsoft-IIS/10.0&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Origin: *&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Authorization, Range&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Methods: GET,HEAD,OPTIONS,POST,PUT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Credentials: true&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Date: Wed, 11 Nov 2020 15:52:32 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Connection: close&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Length: 6531496&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Range: bytes 0-6531495/6531496&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;&#x27;&#xA;Probing mpegts score:50 size:2048&#xA;[mpegts @ 000001d0e7bbd200] Format mpegts probed with size=2048 and score=50&#xA;[mpegts @ 000001d0e7bbd200] Probe: 7648, score: 41, dvhs_score: -2, fec_score: -2&#xA;[mpegts @ 000001d0e7bbd200] Filter: pid=0x11 type=1&#xA;[mpegts @ 000001d0e7bbd200] Filter: pid=0x0 type=1&#xA;[mpegts @ 000001d0e7bbd200] Filter: pid=0x12 type=1&#xA;[mpegts @ 000001d0e7bbd200] SDT:&#xA;[mpegts @ 000001d0e7bbd200] tag: 0x48 len=18&#xA;[mpegts @ 000001d0e7bbd200] new_program: id=0x0001&#xA;[mpegts @ 000001d0e7bbd200] PAT:&#xA;[mpegts @ 000001d0e7bbd200] sid=0x1 pid=0x1000&#xA;[mpegts @ 000001d0e7bbd200] new_program: id=0x0001&#xA;[mpegts @ 000001d0e7bbd200] Filter: pid=0x1000 type=1&#xA;[mpegts @ 000001d0e7bbd200] PMT: len 21&#xA;[mpegts @ 000001d0e7bbd200] sid=0x1 sec_num=0/0 version=0 tid=2&#xA;[mpegts @ 000001d0e7bbd200] pcr_pid=0x100&#xA;[mpegts @ 000001d0e7bbd200] Filter: pid=0x100 type=0&#xA;[mpegts @ 000001d0e7bbd200] stream=0 stream_type=f pid=100 prog_reg_desc=&#xA;[mpegts @ 000001d0e7bbd200] tuning done&#xA;[mpegts @ 000001d0e7bbd200] Before avformat_find_stream_info() pos: 0 bytes read:7648 seeks:0 nb_streams:1&#xA;[mpegts @ 000001d0e7bbd200] Skipping after seek&#xA;[mpegts @ 000001d0e7bbd200] SDT:&#xA;[mpegts @ 000001d0e7bbd200] tag: 0x48 len=18&#xA;[mpegts @ 000001d0e7bbd200] new_program: id=0x0001&#xA;[mpegts @ 000001d0e7bbd200] PAT:&#xA;[mpegts @ 000001d0e7bbd200] sid=0x1 pid=0x1000&#xA;[mpegts @ 000001d0e7bbd200] new_program: id=0x0001&#xA;[mpegts @ 000001d0e7bbd200] PMT: len 21&#xA;[mpegts @ 000001d0e7bbd200] sid=0x1 sec_num=0/0 version=0 tid=2&#xA;[mpegts @ 000001d0e7bbd200] pcr_pid=0x100&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[mpegts @ 000001d0e7bbd200] probing stream 0 pp:2500&#xA;Probing aac score:51 size:2640&#xA;Probing flac score:13 size:2640&#xA;[mpegts @ 000001d0e7bbd200] Probe with size=2640, packets=1 detected aac with score=51&#xA;[mpegts @ 000001d0e7bbd200] probed stream 0&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;    Last message repeated 11 times&#xA;[mpegts @ 000001d0e7bbd200] max_analyze_duration 5000000 reached at 5014800 microseconds st:0&#xA;[tcp @ 000001d0e7c31480] Original list of addresses:&#xA;[tcp @ 000001d0e7c31480] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31480] Interleaved list of addresses:&#xA;[tcp @ 000001d0e7c31480] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31480] Starting connection attempt to 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31480] Successfully connected to 144.2.127.86 port 80&#xA;[http @ 000001d0e7bbe2c0] request: GET /KFYI-AM_2020-10-30_09-05-26.ts HTTP/1.1&#xA;User-Agent: Lavf/58.45.100&#xA;Accept: */*&#xA;Range: bytes=6281496-&#xA;Connection: close&#xA;Host: tyberis.com&#xA;Icy-MetaData: 1&#xA;&#xA;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;HTTP/1.1 206 Partial Content&#x27;&#xA;[http @ 000001d0e7bbe2c0] http_code=206&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Type: video/vnd.dlna.mpeg-tts&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Last-Modified: Tue, 10 Nov 2020 19:12:18 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Accept-Ranges: bytes&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;ETag: "7c6a9e6895b7d61:0"&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Server: Microsoft-IIS/10.0&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Origin: *&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Authorization, Range&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Methods: GET,HEAD,OPTIONS,POST,PUT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Credentials: true&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Date: Wed, 11 Nov 2020 15:52:32 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Connection: close&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Length: 250000&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Range: bytes 6281496-6531495/6531496&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;&#x27;&#xA;[mpegts @ 000001d0e7bbd200] Skipping after seek&#xA;[mpegts @ 000001d0e7bbd200] Probe: 763, score: 5, dvhs_score: 1, fec_score: 1&#xA;[mpegts @ 000001d0e7bbd200] Probe: 8192, score: 44, dvhs_score: -3, fec_score: -3&#xA;[tcp @ 000001d0e7c31580] Original list of addresses:&#xA;[tcp @ 000001d0e7c31580] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31580] Interleaved list of addresses:&#xA;[tcp @ 000001d0e7c31580] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31580] Starting connection attempt to 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31580] Successfully connected to 144.2.127.86 port 80&#xA;[http @ 000001d0e7bbe2c0] request: GET /KFYI-AM_2020-10-30_09-05-26.ts HTTP/1.1&#xA;User-Agent: Lavf/58.45.100&#xA;Accept: */*&#xA;Range: bytes=6266023-&#xA;Connection: close&#xA;Host: tyberis.com&#xA;Icy-MetaData: 1&#xA;&#xA;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;HTTP/1.1 206 Partial Content&#x27;&#xA;[http @ 000001d0e7bbe2c0] http_code=206&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Type: video/vnd.dlna.mpeg-tts&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Last-Modified: Tue, 10 Nov 2020 19:12:18 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Accept-Ranges: bytes&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;ETag: "7c6a9e6895b7d61:0"&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Server: Microsoft-IIS/10.0&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Origin: *&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Authorization, Range&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Methods: GET,HEAD,OPTIONS,POST,PUT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Credentials: true&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Date: Wed, 11 Nov 2020 15:52:32 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Connection: close&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Length: 265473&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Range: bytes 6266023-6531495/6531496&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;&#x27;&#xA;[tcp @ 000001d0e7c31480] Original list of addresses:&#xA;[tcp @ 000001d0e7c31480] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31480] Interleaved list of addresses:&#xA;[tcp @ 000001d0e7c31480] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31480] Starting connection attempt to 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31480] Successfully connected to 144.2.127.86 port 80&#xA;[http @ 000001d0e7bbe2c0] request: GET /KFYI-AM_2020-10-30_09-05-26.ts HTTP/1.1&#xA;User-Agent: Lavf/58.45.100&#xA;Accept: */*&#xA;Range: bytes=6281644-&#xA;Connection: close&#xA;Host: tyberis.com&#xA;Icy-MetaData: 1&#xA;&#xA;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;HTTP/1.1 206 Partial Content&#x27;&#xA;[http @ 000001d0e7bbe2c0] http_code=206&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Type: video/vnd.dlna.mpeg-tts&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Last-Modified: Tue, 10 Nov 2020 19:12:18 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Accept-Ranges: bytes&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;ETag: "7c6a9e6895b7d61:0"&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Server: Microsoft-IIS/10.0&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Origin: *&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Authorization, Range&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Methods: GET,HEAD,OPTIONS,POST,PUT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Credentials: true&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Date: Wed, 11 Nov 2020 15:52:33 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Connection: close&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Length: 249852&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Range: bytes 6281644-6531495/6531496&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;&#x27;&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;    Last message repeated 88 times&#xA;[tcp @ 000001d0e7c31580] Original list of addresses:&#xA;[tcp @ 000001d0e7c31580] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31580] Interleaved list of addresses:&#xA;[tcp @ 000001d0e7c31580] Address 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31580] Starting connection attempt to 144.2.127.86 port 80&#xA;[tcp @ 000001d0e7c31580] Successfully connected to 144.2.127.86 port 80&#xA;[http @ 000001d0e7bbe2c0] request: GET /KFYI-AM_2020-10-30_09-05-26.ts HTTP/1.1&#xA;User-Agent: Lavf/58.45.100&#xA;Accept: */*&#xA;Range: bytes=0-&#xA;Connection: close&#xA;Host: tyberis.com&#xA;Icy-MetaData: 1&#xA;&#xA;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;HTTP/1.1 206 Partial Content&#x27;&#xA;[http @ 000001d0e7bbe2c0] http_code=206&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Type: video/vnd.dlna.mpeg-tts&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Last-Modified: Tue, 10 Nov 2020 19:12:18 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Accept-Ranges: bytes&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;ETag: "7c6a9e6895b7d61:0"&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Server: Microsoft-IIS/10.0&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Origin: *&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Authorization, Range&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Methods: GET,HEAD,OPTIONS,POST,PUT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Access-Control-Allow-Credentials: true&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Date: Wed, 11 Nov 2020 15:52:33 GMT&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Connection: close&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Length: 6531496&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;Content-Range: bytes 0-6531495/6531496&#x27;&#xA;[http @ 000001d0e7bbe2c0] header=&#x27;&#x27;&#xA;[mpegts @ 000001d0e7bbd200] stream 0: start_time: 1.4 duration: 1097.98&#xA;[mpegts @ 000001d0e7bbd200] format: start_time: 1.4 duration: 1097.98 (estimate from pts) bitrate=47 kb/s&#xA;[mpegts @ 000001d0e7bbd200] After avformat_find_stream_info() pos: 0 bytes read:329238 seeks:3 frames:117&#xA;Input #0, mpegts, from &#x27;http://tyberis.com/KFYI-AM_2020-10-30_09-05-26.ts&#x27;:&#xA;  Duration: 00:18:17.98, start: 1.400000, bitrate: 47 kb/s&#xA;  Program 1&#xA;    Metadata:&#xA;      service_name    : Service01&#xA;      service_provider: FFmpeg&#xA;    Stream #0:0[0x100], 117, 1/90000: Audio: aac (HE-AACv2) ([15][0][0][0] / 0x000F), 44100 Hz, stereo, fltp, 45 kb/s&#xA;Successfully opened the file.&#xA;Parsing a group of options: output url out.wav.&#xA;Applying option af (set audio filters) with argument aresample=async=1.&#xA;Applying option f (force format) with argument wav.&#xA;Applying option acodec (force audio codec (&#x27;copy&#x27; to copy stream)) with argument pcm_s16le.&#xA;Applying option ac (set number of audio channels) with argument 2.&#xA;Successfully parsed a group of options.&#xA;Opening an output file: out.wav.&#xA;[file @ 000001d0e7c06200] Setting default whitelist &#x27;file,crypto,data&#x27;&#xA;Successfully opened the file.&#xA;Stream mapping:&#xA;  Stream #0:0 -> #0:0 (aac (native) -> pcm_s16le (native))&#xA;Press [q] to stop, [?] for help&#xA;cur_dts is invalid st:0 (0) [init:0 i_done:0 finish:0] (this is harmless if it occurs once at the start per stream)&#xA;[mpegts @ 000001d0e7bbd200] Skipping after seek&#xA;[mpegts @ 000001d0e7bbd200] SDT:&#xA;[mpegts @ 000001d0e7bbd200] tag: 0x48 len=18&#xA;[mpegts @ 000001d0e7bbd200] new_program: id=0x0001&#xA;[mpegts @ 000001d0e7bbd200] PAT:&#xA;[mpegts @ 000001d0e7bbd200] sid=0x1 pid=0x1000&#xA;[mpegts @ 000001d0e7bbd200] new_program: id=0x0001&#xA;[mpegts @ 000001d0e7bbd200] PMT: len 21&#xA;[mpegts @ 000001d0e7bbd200] sid=0x1 sec_num=0/0 version=0 tid=2&#xA;[mpegts @ 000001d0e7bbd200] pcr_pid=0x100&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;detected 4 logical cores&#xA;[Parsed_aresample_0 @ 000001d0e7be5e80] Setting &#x27;async&#x27; to value &#x27;1&#x27;&#xA;[graph_0_in_0_0 @ 000001d0e7beeac0] Setting &#x27;time_base&#x27; to value &#x27;1/44100&#x27;&#xA;[graph_0_in_0_0 @ 000001d0e7beeac0] Setting &#x27;sample_rate&#x27; to value &#x27;44100&#x27;&#xA;[graph_0_in_0_0 @ 000001d0e7beeac0] Setting &#x27;sample_fmt&#x27; to value &#x27;fltp&#x27;&#xA;[graph_0_in_0_0 @ 000001d0e7beeac0] Setting &#x27;channel_layout&#x27; to value &#x27;0x3&#x27;&#xA;[graph_0_in_0_0 @ 000001d0e7beeac0] tb:1/44100 samplefmt:fltp samplerate:44100 chlayout:0x3&#xA;[format_out_0_0 @ 000001d0e7bf0080] Setting &#x27;sample_fmts&#x27; to value &#x27;s16&#x27;&#xA;[format_out_0_0 @ 000001d0e7bf0080] Setting &#x27;channel_layouts&#x27; to value &#x27;0x3&#x27;&#xA;[AVFilterGraph @ 000001d0e7be6540] query_formats: 4 queried, 9 merged, 0 already done, 0 delayed&#xA;[Parsed_aresample_0 @ 000001d0e7be5e80] [SWR @ 000001d0e81bb8c0] Using fltp internally between filters&#xA;[Parsed_aresample_0 @ 000001d0e7be5e80] ch:2 chl:stereo fmt:fltp r:44100Hz -> ch:2 chl:stereo fmt:s16 r:44100Hz&#xA;Output #0, wav, to &#x27;out.wav&#x27;:&#xA;  Metadata:&#xA;    ISFT            : Lavf58.45.100&#xA;    Stream #0:0, 0, 1/44100: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 44100 Hz, stereo, s16, 1411 kb/s&#xA;    Metadata:&#xA;      encoder         : Lavc58.91.100 pcm_s16le&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 7 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;(...)&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 4 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;timestamp discontinuity for stream #0:0 (id=256, type=audio): 69892061, new offset= -71292061&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;[aac @ 000001d0e7c0ed80] illegal icc&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 7 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;[mpegts @ 000001d0e7bbd200] pid=100 pes_code=0x1c0&#xA;[aac @ 000001d0e7c0ed80] ChannelElement 1.0 missing&#xA;    Last message repeated 9 times&#xA;(...)&#xA;size=    5000kB time=00:00:29.02 bitrate=1411.2kbits/s speed=6.11x&#xA;video:0kB audio:5000kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.001523%&#xA;Input file #0 (http://tyberis.com/KFYI-AM_2020-10-30_09-05-26.ts):&#xA;  Input stream #0:0 (audio): 625 packets read (174267 bytes); 625 frames decoded (1280000 samples);&#xA;  Total: 625 packets (174267 bytes) demuxed&#xA;Output file #0 (out.wav):&#xA;  Output stream #0:0 (audio): 625 frames encoded (1280000 samples); 625 packets muxed (5120000 bytes);&#xA;  Total: 625 packets (5120000 bytes) muxed&#xA;625 frames successfully decoded, 0 decoding errors&#xA;[AVIOContext @ 000001d0e7c2e280] Statistics: 4 seeks, 22 writeouts&#xA;[AVIOContext @ 000001d0e7bc9780] Statistics: 533494 bytes read, 3 seeks```&#xA;

    &#xA;