;(function() { window.createMeasureObserver = (measureName) => { var markPrefix = `_uol-measure-${measureName}-${new Date().getTime()}`; performance.mark(`${markPrefix}-start`); return { end: function() { performance.mark(`${markPrefix}-end`); performance.measure(`uol-measure-${measureName}`, `${markPrefix}-start`, `${markPrefix}-end`); performance.clearMarks(`${markPrefix}-start`); performance.clearMarks(`${markPrefix}-end`); } } }; /** * Gerenciador de eventos */ window.gevent = { stack: [], RUN_ONCE: true, on: function(name, callback, once) { this.stack.push([name, callback, !!once]); }, emit: function(name, args) { for (var i = this.stack.length, item; i--;) { item = this.stack[i]; if (item[0] === name) { item[1](args); if (item[2]) { this.stack.splice(i, 1); } } } } }; var runningSearch = false; var hadAnEvent = true; var elementsToWatch = window.elementsToWatch = new Map(); var innerHeight = window.innerHeight; // timestamp da última rodada do requestAnimationFrame // É usado para limitar a procura por elementos visíveis. var lastAnimationTS = 0; // verifica se elemento está no viewport do usuário var isElementInViewport = function(el) { var rect = el.getBoundingClientRect(); var clientHeight = window.innerHeight || document.documentElement.clientHeight; // renderizando antes, evitando troca de conteúdo visível no chartbeat-related-content if(el.className.includes('related-content-front')) return true; // garante que usa ao mínimo 280px de margem para fazer o lazyload var margin = clientHeight + Math.max(280, clientHeight * 0.2); // se a base do componente está acima da altura da tela do usuário, está oculto if(rect.bottom < 0 && rect.bottom > margin * -1) { return false; } // se o topo do elemento está abaixo da altura da tela do usuário, está oculto if(rect.top > margin) { return false; } // se a posição do topo é negativa, verifica se a altura dele ainda // compensa o que já foi scrollado if(rect.top < 0 && rect.height + rect.top < 0) { return false; } return true; }; var asynxNextFreeTime = () => { return new Promise((resolve) => { if(window.requestIdleCallback) { window.requestIdleCallback(resolve, { timeout: 5000, }); } else { window.requestAnimationFrame(resolve); } }); }; var asyncValidateIfElIsInViewPort = function(promise, el) { return promise.then(() => { if(el) { if(isElementInViewport(el) == true) { const cb = elementsToWatch.get(el); // remove da lista para não ser disparado novamente elementsToWatch.delete(el); cb(); } } }).then(asynxNextFreeTime); }; // inicia o fluxo de procura de elementos procurados var look = function() { if(window.requestIdleCallback) { window.requestIdleCallback(findByVisibleElements, { timeout: 5000, }); } else { window.requestAnimationFrame(findByVisibleElements); } }; var findByVisibleElements = function(ts) { var elapsedSinceLast = ts - lastAnimationTS; // se não teve nenhum evento que possa alterar a página if(hadAnEvent == false) { return look(); } if(elementsToWatch.size == 0) { return look(); } if(runningSearch == true) { return look(); } // procura por elementos visíveis apenas 5x/seg if(elapsedSinceLast < 1000/5) { return look(); } // atualiza o último ts lastAnimationTS = ts; // reseta status de scroll para não entrar novamente aqui hadAnEvent = false; // indica que está rodando a procura por elementos no viewport runningSearch = true; const done = Array.from(elementsToWatch.keys()).reduce(asyncValidateIfElIsInViewPort, Promise.resolve()); // obtém todos os elementos que podem ter view contabilizados //elementsToWatch.forEach(function(cb, el) { // if(isElementInViewport(el) == true) { // // remove da lista para não ser disparado novamente // elementsToWatch.delete(el); // cb(el); // } //}); done.then(function() { runningSearch = false; }); // reinicia o fluxo de procura look(); }; /** * Quando o elemento `el` entrar no viewport (-20%), cb será disparado. */ window.lazyload = function(el, cb) { if(el.nodeType != Node.ELEMENT_NODE) { throw new Error("element parameter should be a Element Node"); } if(typeof cb !== 'function') { throw new Error("callback parameter should be a Function"); } elementsToWatch.set(el, cb); } var setEvent = function() { hadAnEvent = true; }; window.addEventListener('scroll', setEvent, { capture: true, ive: true }); window.addEventListener('click', setEvent, { ive: true }); window.addEventListener('resize', setEvent, { ive: true }); window.addEventListener('load', setEvent, { once: true, ive: true }); window.addEventListener('DOMContentLoaded', setEvent, { once: true, ive: true }); window.gevent.on('allJSLoadedAndCreated', setEvent, window.gevent.RUN_ONCE); // inicia a validação look(); })();
  • AssineUOL
Logo Pagbenk Seu dinheiro rende mais
Topo

'É difícil prever o futuro', diz ministro sobre risco de racionamento

O ministro de Minas e Energia Bento Albuquerque em pronunciamento - Reprodução
O ministro de Minas e Energia Bento Albuquerque em pronunciamento Imagem: Reprodução

Do UOL, em São Paulo

02/09/2021 18h02

O ministro de Minas e Energia, Bento Albuquerque, disse hoje ser "difícil prever o futuro" ao ser questionado sobre a possibilidade de risco de racionamento em meio a crise hídrica no Brasil, durante entrevista à GloboNews.

É difícil prever o futuro
Ministro de Minas e Energia, em entrevista

"Trabalhamos com cenários, e o cenário de hoje aponta que não precisaremos adotar medidas de racionamento em outubro e novembro. E a previsão de agora é que, para setembro, ainda teremos baixas afluências nas principais bacias hidrográficas", completou, em seguida.

Apesar de atravessar a pior crise hídrica em 90 anos, e com as medidas para tentar economizar energia, o presidente Jair Bolsonaro (sem partido) praticamente proibiu que o governo use a palavra "racionamento".

Na última terça-feira (31), o governo de divulgou a criação de uma nova bandeira para a conta de luz, que aumenta o valor da taxa extra em 50%. Chamada de bandeira de escassez hídrica, a taxa tem o valor de R$ 14,20 por 100 kWh, e será aplicada à conta de luz a partir desta quarta-feira (1º). A bandeira ficará em vigor até 30 de abril de 2022.

As bandeiras tarifárias são independentes da tarifa de energia, e acrescentadas ao valor da conta dependendo das condições de geração de energia no setor elétrico. Quando o cenário é favorável, não há acréscimo (bandeira verde). A bandeira amarela indica cenário menos favorável, enquanto as vermelhas (patamar 1 e 2) apontam para condições custosas de geração de energia.

O objetivo das bandeiras tarifárias é remunerar o uso de usinas termelétricas, que têm custo mais alto. As termelétricas estão sendo utilizadas por causa da seca, que diminuiu o reservatório de hidrelétricas e prejudicou a geração de energia.

Medidas para evitar apagões

Desde que a Câmara de Regras Excepcionais para a Gestão Hidroenergética (Creg) foi criada, o governo adotou diversas ações para tentar evitar apagões ou ainda a necessidade de um racionamento de energia.

A termelétrica William Arjona, em Mato Grosso do Sul, por exemplo, tem um custo variável superior a R$ 2,4 mil por megawatt-hora (MWh), e a importação de energia da Argentina e do Uruguai, por exemplo, custa mais de R$ 2 mil por megawatt-hora (MWh). Por dia, o Brasil importa 2 mil megawatts dos países vizinhos. Novas ações com custos ainda mais elevados devem ser adotadas ao longo das próximas semanas.

As despesas com térmicas mais caras são pagas pelas distribuidoras praticamente à vista, e o ree ao consumidor pode ser feito de duas formas: ou pelas bandeiras, ou no reajuste anual, com incidência de juros. Cálculos da agência indicaram que os recursos não seriam suficientes para cobrir os custos das térmicas.

A Aneel projetou um déficit de R$ 8 bilhões na conta Bandeiras no final do ano. Somente as medidas adotadas pelo governo devem aumentar o rombo em mais de R$ 2,4 bilhões a R$ 4,3 bilhões. As empresas reclamam que estão com o caixa no limite e que não há como carregar valores tão elevados por tanto tempo.