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

Ovni? O que é o objeto estranho que robô na Nasa fotografou no céu de Marte

Nasa
Imagem: Nasa

Barbara Mannara

Colaboração para Tilt, do Rio de Janeiro

02/12/2022 12h14

O robô Perseverance, da Nasa, que está explorando Marte, fotografou algo estranho no céu do planeta no último domingo (27). Participantes do fórum Reddit têm formulado diversas teorias sobre o que poderia ser este óvni (Objeto Voador Não Identificado). Será que aliens resolveram fazer contato?

Outras hipóteses criativas levantadas foram: uma formiga ando na lente da câmera e um saco plástico errante.

Mas a Nasa já esclareceu o mistério e, para decepção de muitos, a resposta é bem mais simples do esperavam. Spoiler: não há marcianos envolvidos.

Na verdade, o objeto sequer existe na vida real. É apenas uma mancha na imagem, ocasionada por falhas nos pixels (pequenos pontos que formam uma foto digital) na câmera.

"São causados por pedaços microscópicos de detritos no sensor. A maioria dos geradores de imagens apresenta este tipo de defeito", disse o cientista de imagem, Justin Maki, em um comunicado da Nasa. E completa: "Eles geralmente só são perceptíveis quando a câmera registra imagens do céu ou de alguma outra superfície radiométrica plana".

Para comprovar a tesa, basta olhar uma fotografia que o Perseverance registrou por outro ângulo: o ponto preto está lá, sobre o solo arenoso do planeta.

marte perseverance  - Nasa - Nasa
No centro da imagem, podemos ver o mesmo "objeto" escuro, comprovando se tratar de uma interferência no sensor da câmera
Imagem: Nasa

Fotos curiosas em Marte

Não é a primeira vez que algo assim acontece. O Curiosity, outro rover da Nasa que está explorando Marte, em outubro publicou uma foto com um suposto óvni — que também se tratava de uma ilusão de ótica gerada por pixels ruins.

Os processadores de imagem costumam corrigir estas falhas posteriormente, mas os arquivos enviados pelos robôs chega em formato RAW, sem ajustes.

O próprio Perseverance já fotografou outras coisas estranhas em sua viagem por Marte, acendendo a imaginação das pessoas, incluindo algo semelhante a espaguete e um pedaço de "papel alumínio" — que na verdade eram resquícios dos aparelhos de seu próprio pouso (o que intensificou a discussão sobre lixo humano estar invadindo o espaço).

As pessoas também têm enxergado formas nas rochas do planeta, como uma cobra, uma porta e um gato. Veja um compilado destas figuras.

O Perseverance chegou ao planeta vermelho em 2021 para explorar a Cratera Jezero, um antigo lago marciano. Sua missão é procurar sinais de vida antiga e coletar amostras de rochas para futuramente serem enviadas à Terra.