;(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
Topo

Diogo Schelp

Isolamento pode evitar mais de 89.000 mortes em São Paulo, diz estudo

06.04.2020 - Paciente chega no Hospital de Campanha no Estádio do Pacaembu em São Paulo (SP), nesta segunda-feira (6). Local a a receber exclusivamente, pacientes com suspeita ou confirmados de estarem com a Covid-19, do novo coronavírus - Ettore Chiereguini/Futura Press/Estadão Conteúdo
06.04.2020 - Paciente chega no Hospital de Campanha no Estádio do Pacaembu em São Paulo (SP), nesta segunda-feira (6). Local a a receber exclusivamente, pacientes com suspeita ou confirmados de estarem com a Covid-19, do novo coronavírus Imagem: Ettore Chiereguini/Futura Press/Estadão Conteúdo

Colunista do UOL

08/04/2020 12h52

As medidas de distanciamento social precoce adotadas na região metropolitana de São Paulo podem evitar mais de 89.000 mortes por covid-19 no intervalo de dois meses, mostra estudo divulgado nesta quarta-feira (8) por um grupo de oito pesquisadores, alguns dos quais integraram a equipe do ministro da Saúde Luiz Henrique Mandetta até recentemente.

O estudo calculou a taxa de transmissão do vírus na cidade, ou seja, a média de pessoas infectadas por cada indivíduo com a doença, ao longo das últimas semanas, desde o registro do primeiro caso confirmado, em 26 de fevereiro, e fez uma projeção do número de leitos em UTI necessários para lidar com a epidemia.

Com as medidas de distanciamento social que foram adotadas voluntariamente ou por medidas governamentais desde meados de março, o estudo projeta um total de 1.999 mortos por covid-19 até o final de abril.

Sem as medidas de isolamento, no entanto, a pandemia causaria 1.783 mortes nos primeiros 30 dias e 89.349 no segundo mês.

A explicação está na capacidade da rede de saúde da Grande São Paulo de absorver os casos graves da doença. Na hipótese da ausência de medidas de distanciamento social, o número de pacientes graves seria mais que o dobro dos leitos em UTI disponíveis nos primeiros 30 dias — e 14 vezes nos 30 dias seguintes. Ou seja, o sistema de saúde entraria em colapso.

Com as medidas de distanciamento em curso, porém, as Unidades de Terapia Intensiva existentes dão conta da demanda.

Um dos dados mais reveladores do estudo é o impacto das medidas de distanciamento social (cancelamento de eventos com grande número pessoas, fechamento de escolas e de comércio) na taxa de transmissão do vírus (chamado de "número básico de reprodução"). Antes de os moradores de São Paulo começarem a ficar em casa, este número estava perto de 2. Ou seja, cada caso de covid-19 gerava outros dois pacientes. Durante o período de adoção das medidas de distanciamento social, porém, a taxa caiu para perto de 1.

O estudo é assinado por Fabiana Ganem, Victor Bertollo Gomes Porto, Silvano Barbosa de Oliveira, Fabio Macedo Mendes, Wildo Navegantes de Araújo, Helder I. Nakaya, Fredi A. Diaz-Quijano e Júlio Croda.