---
id: af4afb223120f7348cdfc9fd
title: Mapear órbitas
challengeType: 5
forumTopicId: 16021
dashedName: map-the-debris
---
# --description--
De acordo com a Terceira Lei de Kepler, o período orbital $T$ de dois pontos de massa orbitando uma à outra em uma órbita circular ou elíptica é:
$$ T = 2 \pi \sqrt{\frac{a^{3}}{\mu}} $$
- $a$ é o eixo semimaior da órbita
- $μ = GM$ é o parâmetro gravitacional padrão
- $G$ é a constante gravitacional,
- $M$ é a massa do maior corpo.
Retorna um novo array que transforma a altitude média dos elementos em seus períodos órbita (em segundos).
O array conterá objetos no formato `{name: 'name', avgAlt: avgAlt}`.
Os valores devem estar arredondados para o número inteiro mais próximo. O corpo sendo orbitado é a Terra.
O raio da terra é 6367,4447 quilômetros, e o valor de GM da térra é 398600,4418 km3s-2.
# --hints--
`orbitalPeriod([{name : "sputnik", avgAlt : 35873.5553}])` deve retornar `[{name: "sputnik", orbitalPeriod: 86400}]`.
```js
assert.deepEqual(orbitalPeriod([{ name: 'sputnik', avgAlt: 35873.5553 }]), [
{ name: 'sputnik', orbitalPeriod: 86400 }
]);
```
`orbitalPeriod([{name: "iss", avgAlt: 413.6}, {name: "hubble", avgAlt: 556.7}, {name: "moon", avgAlt: 378632.553}])` deve retornar `[{name : "iss", orbitalPeriod: 5557}, {name: "hubble", orbitalPeriod: 5734}, {name: "moon", orbitalPeriod: 2377399}]`.
```js
assert.deepEqual(
orbitalPeriod([
{ name: 'iss', avgAlt: 413.6 },
{ name: 'hubble', avgAlt: 556.7 },
{ name: 'moon', avgAlt: 378632.553 }
]),
[
{ name: 'iss', orbitalPeriod: 5557 },
{ name: 'hubble', orbitalPeriod: 5734 },
{ name: 'moon', orbitalPeriod: 2377399 }
]
);
```
# --seed--
## --seed-contents--
```js
function orbitalPeriod(arr) {
const GM = 398600.4418;
const earthRadius = 6367.4447;
return arr;
}
orbitalPeriod([{name : "sputnik", avgAlt : 35873.5553}]);
```
# --solutions--
```js
function orbitalPeriod(arr) {
const GM = 398600.4418;
const earthRadius = 6367.4447;
const TAU = 2 * Math.PI;
return arr.map(function(obj) {
return {
name: obj.name,
orbitalPeriod: Math.round(TAU * Math.sqrt(Math.pow(obj.avgAlt+earthRadius, 3)/GM))
};
});
}
```