Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/thomasafink/galactic_star_map_of_the_kepler_systems

A Galactic Star Map of all Stars Mapped by NASA's Kepler / K2 Telescope
https://github.com/thomasafink/galactic_star_map_of_the_kepler_systems

astronomy astrophysics esa exoplanets kepler nasa

Last synced: about 2 months ago
JSON representation

A Galactic Star Map of all Stars Mapped by NASA's Kepler / K2 Telescope

Awesome Lists containing this project

README

        

# Galactic Star Map of The Kepler Systems
This repository contains the code for generating a Galactic Star Map of all stars mapped by NASA's Kepler / K2 Telescope. The Kepler mission has provided an unprecedented dataset for identifying exoplanets in our galaxy downloaded from Kaggle at https://www.kaggle.com/datasets/nasa/kepler-exoplanet-search-results and the background 60MB starmap is provided by ESA's Gaia satellite downloaded from https://sci.esa.int/web/gaia/-/60169-gaia-s-sky-in-colour. This is a simple visualalization of the positions of the Kepler star systems.

## Importing Libraries
```
import numpy as np
import matplotlib.pyplot as plt
import pandas as pd
from astropy.coordinates import SkyCoord
import astropy.units as u
```
This section imports essential Python libraries for data handling and visualization. numpy is used for numerical operations, matplotlib.pyplot for plotting, pandas for data manipulation, and astropy components for astronomical calculations, specifically for converting celestial coordinates.

## Setting Global Plot Aesthetics
```
plt.rcParams['text.color'] = '#cccccc'
plt.rcParams['axes.labelcolor'] = '#cccccc'
plt.rcParams['xtick.color'] = '#cccccc'
plt.rcParams['ytick.color'] = '#cccccc'
plt.rcParams['figure.facecolor'] = '#0c0d0d'
plt.rcParams['axes.facecolor'] = '#0c0d0d'
```
This part of the code customizes the appearance of the plots. It sets the colors of text, labels, ticks, and the background to ensure the plot is visually coherent and aesthetically pleasing against a dark background, mimicking a night sky.

## Loading the Data and Pre-processing
```
data = plt.imread("Gaia_EDR3_flux_hammer_8k.png")
kepler_data = pd.read_csv('kepler.csv')
kepler_data['ra'] = pd.to_numeric(kepler_data['ra'], errors='coerce')
kepler_data['dec'] = pd.to_numeric(kepler_data['dec'], errors='coerce')
kepler_data = kepler_data.dropna(subset=['ra', 'dec'])
```

Here, the background image for the plot is loaded, and the Kepler dataset is read from a CSV file. The ra (right ascension) and dec (declination) columns are converted to numeric types, handling non-numeric values gracefully by coercing them to NaNs and then dropping any rows with NaNs in these crucial columns. This ensures the dataset is clean and ready for further processing.

## Coordinate Transformation
```
for i, row in kepler_data.iterrows():
coord = SkyCoord(ra=row['ra'] * u.degree, dec=row['dec'] * u.degree, frame='icrs')
galactic_coord = coord.galactic
kepler_data.at[i, 'galactic_l'] = galactic_coord.l.degree
kepler_data.at[i, 'galactic_b'] = galactic_coord.b.degree
```
In this loop, each star's coordinates are transformed from the Equatorial system (right ascension and declination) to the Galactic coordinate system (longitude and latitude). This step aligns the stars according to the Milky Way's structure, preparing the data for a galactic-centric visualization.

**Given:**

![Given](https://latex.codecogs.com/png.latex?%5Cinline%20%5Calpha,%20%5Cdelta%3A%20%5Ctext%7BRight%20Ascension%20and%20Declination%20in%20the%20Equatorial%20coordinate%20system.%7D%5C%5C%20%5Calpha_%7BGP%7D,%20%5Cdelta_%7BGP%7D%3A%20%5Ctext%7BRight%20Ascension%20and%20Declination%20of%20the%20North%20Galactic%20Pole%20(NGP).%7D%5C%5C%20l_%7BNCP%7D%3A%20%5Ctext%7BGalactic%20longitude%20of%20the%20North%20Celestial%20Pole%20(NCP).%7D)

**Find the angular distance (θ) from the Galactic North Pole (GNP):**

![Angular Distance](https://latex.codecogs.com/png.latex?%5Cinline%20%5Ccos%28%5Ctheta%29%20%3D%20%5Csin%28%5Cdelta_%7BGP%7D%29%20%5Ccdot%20%5Csin%28%5Cdelta%29%20%2B%20%5Ccos%28%5Cdelta_%7BGP%7D%29%20%5Ccdot%20%5Ccos%28%5Cdelta%29%20%5Ccdot%20%5Ccos%28%5Calpha%20-%20%5Calpha_%7BGP%7D%29)

**Calculate the Galactic Latitude (b):**

![Galactic Latitude](https://latex.codecogs.com/png.latex?%5Cinline%20b%20%3D%2090%5E%5Ccirc%20-%20%5Ctheta)

**Compute the Galactic Longitude (l):**

![Galactic Longitude Sine](https://latex.codecogs.com/png.latex?%5Cinline%20%5Csin%28l%20-%20l_%7BNCP%7D%29%20%3D%20%5Cfrac%7B%5Ccos%28%5Cdelta%29%20%5Ccdot%20%5Csin%28%5Calpha%20-%20%5Calpha_%7BGP%7D%29%7D%7B%5Csin%28%5Ctheta%29%7D)

![Galactic Longitude Cosine](https://latex.codecogs.com/png.latex?%5Cinline%20%5Ccos%28l%20-%20l_%7BNCP%7D%29%20%3D%20%5Cfrac%7B%5Csin%28%5Cdelta%29%20-%20%5Csin%28%5Cdelta_%7BGP%7D%29%20%5Ccdot%20%5Ccos%28%5Ctheta%29%7D%7B%5Ccos%28%5Cdelta_%7BGP%7D%29%20%5Ccdot%20%5Csin%28%5Ctheta%29%7D)

![Full Galactic Longitude Calculation](https://latex.codecogs.com/png.latex?%5Cinline%20l%20%3D%20%5Ctext%7Batan2%7D%28%5Csin%28l%20-%20l_%7BNCP%7D%29,%20%5Ccos%28l%20-%20l_%7BNCP%7D%29%29%20%2B%20l_%7BNCP%7D)

## Adjusting and Plotting the Data
```
galactic_l = np.radians(kepler_data['galactic_l'])
galactic_b = np.radians(kepler_data['galactic_b'])
galactic_l = -galactic_l
```
The Galactic longitude (galactic_l) is converted to radians and then inverted to align with the orientation of the Milky Way in the background image. This ensures that the data visualization accurately reflects the stars' positions within the galaxy.

## Creating the Visualization
```
fig = plt.figure(figsize=(12, 8))
ax0 = fig.add_subplot(111)
ax0.imshow(data)
ax0.axis("off")
ax = fig.add_subplot(111, projection="mollweide", label="polar")
ax.set_facecolor("None")
ax.set_xlabel("Galactic l")
ax.set_ylabel("Galactic b")
ax.set_title("Kepler Survey Sky Map", pad=20, color='#cccccc')
plt.grid(True, color='#fcfcfc', alpha=0.2)
ax.scatter(galactic_l, galactic_b, s=0.001, alpha=0.1, color='#fcfcfc', marker='.')
```

A figure is created with a subplot for displaying the background image of the Milky Way. Another subplot using the Mollweide projection overlays the Kepler data on top of this background. The subplot for the data is made transparent so the background image is visible. The plot is then customized with labels for Galactic longitude and latitude, a title, and a customized grid. The Kepler data is plotted with small, semi-transparent white dots to represent stars, ensuring the visualization is both informative and visually appealing.

## Conclusion
This code creates a detailed and visually engaging map of stars observed by the Kepler telescope, plotted over an image of the Milky Way. The transformation of coordinates to the Galactic system and the careful customization of the plot's aesthetics ensure that the visualization is not only scientifically accurate but also accessible and educational for viewers, highlighting the distribution of exoplanet-host