;(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
Grande ideia

Grande ideia

Com matemática, projeto prevê fim de equipamentos contra covid em hospitais

EPIs da Prefeitura de São Paulo - Divulgação/ Prefeitura de São Paulo
EPIs da Prefeitura de São Paulo Imagem: Divulgação/ Prefeitura de São Paulo

Marcos Candido

De Ecoa, em São Paulo

23/06/2020 04h00Atualizada em 23/06/2020 15h35

Uma iniciativa de pesquisadores pode ajudar hospitais a não ficarem sem produtos de higiene durante a pandemia do novo coronavírus. Um programa elaborado pelo Centro de Ciências Matemáticas Aplicadas à Indústria (CeMEAI) ajuda a "prever" quando é preciso reforçar o estoque de EPI de acordo com os índices da doença na região do hospital. O o à ferramenta é aberto e gratuito.

O sistema matemático impede que hospitais desperdicem investimentos. O programa utiliza a taxa de hospitalização da doença no estado em tempo real e o número de leitos disponíveis para definir quantos profissionais, máscaras, aventais devem ser escalados e comprados. Também é possível saber quando o estoque está próximo do fim. Assim, diminui-se a chance de um hospital comprar um monte de recursos e deixar um outro sem, por exemplo.

Projetos assim têm sido possíveis por meio da união de empresas, universidades e entidades públicas para buscar soluções durante a pandemia do novo coronavírus.

Desta vez o programa foi criado pelo centro de pesquisa no Instituto de Ciências Matemáticas e de Computação da Universidade de São Paulo (ICMC-USP), em São Carlos. O departamento recebe investimento público Fundação de Amparo à Pesquisa do Estado de São Paulo (Fapesp). Do outro lado do projeto está a Bionexo, desenvolvedora de soluções digitais para a gestão de saúde no Brasil e na América Latina.

Pelo esforço coletivo foi possível, inclusive, driblar a mudança na divulgação dos dados da Covid-19 pelo governo federal. "Como utilizamos dados estaduais, então não, isso não nos afetou, porque os Estados continuaram a soltar os boletins diariamente", explica o professor Francisco Louzada Neto, professor do ICMC-USP.

A ideia foi desenvolvida após o seminário on-line "Focusing maths of Covid-19 on South America" realizada pela Fapesp no início de junho. Um hospital pediátrico já aderiu e, segundo professor, há interesse de outras instituições. Hospitais em Santa Catarina, São Paulo, Goiás, Rio de Janeiro e Rio Grande do Sul também aderiram ao programa.

Em abril, a mesma instituição produziu um sistema para acompanhar a progressão da doença em tempo real nos municípios do estado de São Paulo e um sistema que calcula o nível de isolamento necessário em cada cidade de acordo com o número de casos confirmados.

Errata: este conteúdo foi atualizado
Ao contrário do que foi publicado no texto original, o sistema matemático garante, e não impede, que hospitais não desperdicem investimentos. A informação foi corrigida às 11h45.

Grande ideia