Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pavelsjo/gp-oracle
https://github.com/pavelsjo/gp-oracle
Last synced: about 1 month ago
JSON representation
- Host: GitHub
- URL: https://github.com/pavelsjo/gp-oracle
- Owner: pavelsjo
- License: unlicense
- Created: 2022-10-25T20:09:15.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2022-10-26T13:49:52.000Z (about 2 years ago)
- Last Synced: 2023-10-17T02:47:48.153Z (about 1 year ago)
- Size: 8.17 MB
- Stars: 0
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Grand Prix Argentina - Race 2
**¿Porqué una carrera de F1 es emocionante?**
Es una pregunta que tiene una respuesta distinta según a quien le preguntemos ¿tú que piensas? y nos da también un contexto ideal para hacer Data Science.
En este sentido, en esta carrera usaremos datos de la Evaluación de Experiencia de los Fanáticos de la Fórmula 1 (F1) y crearemos un experimento para entrenar 5 algoritmos de Machine Learning usando Auto Machine Learning (Auto ML) en Autonomous Data Warehouse (ADW) y con el Feature Importance analizaremos lo que la Inteligencia Artificial "piensa".
`Pre-requisito: para comenzar, se asume que ya el participante tiene aceso a Oracle Cloud Infrastructure (OCI) y un ADW disponible.`
Las (5) vueltas para llegar a la meta son:
## 1. Buscar ADW en nuestra consola de OCI [INICIO]
Desde el inicio en consola **Oracle Cloud Infrastructure (OCI)**, presionando el `Menú de Hamburgesa` ubicado arriba a la izquierda de la pantalla podemos ubicar todas las opciones de la nube:
![img](./img/0-oci-consola.png)
Luego, en el menú que se despliega seleccionamos primero `Oracle Database` y después `Autonomous Data Warehouse`.
Y allí veremos todas las instancias que tenemos creadas.
![img](./img/1-adw-instances.png)
Actualmente mi instancia se llama `ADWF1` y está Available, en este sentido, debes observar un escenario similar con el nombre de base de datos que hayas escogido.
Luego, en caso de que no veas tu actual instancia puedes verificar y ajustar:
- Tenancy. Ejemplo: US East (Ashburn).
- Compartment. Ejemplo: Public Sector.
- Worload Type. Ejemplo: Data Warehouse.Asímismo, dando click en la instancia `ADWF1` llegaremos a los detalles:
![img](./img/2-detalles-de-la-instancia.png)
## 2. Crear un usuario de base de datos llamado F1 uando Databse Actions.
![img](./img/3db-actions.png)
En el siguiente paso nos concentraremos en las Data Base Actions, y haciendo click nos abrirá una nueva pestaña en el navegador y nos preguntara por nuestro usuario (ADMIN) y contraseña.
![img](./img/4-login.png)
Luego, veremos la interfaz principal y seleccionaremos la opción **DATABASE USERS**.
![img](./img/5-db-actions.png)
En este apartado daremos click en el botón `+ Create New User`.
Y finalmente crearemos nuestro usuario `F1` con las opciones que vemos en pantalla:
![img](./img/6-creacion-de-usuario.png)
`Nota: en caso de que no veas estas pantallas, verifica que las ventanas emergentes PopUps de tu navegador este habilitadas, usualmente aparecen con un mensaje visible a la izquierda de la barra de navegación.`
## 3. Cargar un set de datos
Existen varias formas de hacer este paso, y el camino planteado apunta a que un usuario gestor de la base de datos (ADMIN) en su labor de data managment carge los datos y otorge un acceso al científico de datos (F1).
Entonces, aun con el usuario ADMIN abrimos el menú de la hamburgesa que está arriba a la izquierda, y de la solapa `Data Studio` seleccionamos `Data Load.`
![img](./img/7-menu-dbactions.png)
Luego seleccionamos las opciones `LOAD DATA`, `CLOUD STORE` y damos click en `Next`.
![img](./img/8-load-action.png)
Aquí usaremos el siguiente:
- **ENLACE_PUBLICO:** https://objectstorage.us-ashburn-1.oraclecloud.com/n/idi1o0a010nx/b/oci-public-bucket/o/F1_RACES_TRAIN.json
Y lo copiaremos en la barra:
![img](./img/9-url.png)
Con el click izquierdo del mouse, arrastraremos el set de datos `F1_RACES_TRAIN` del panel izquierdo al panel derecho.
![img](./img/10-arrastrar.png)
Luego daremos play al **botón verde** para ejecutar nuestro job, que consiste en, tomar los datos `F1_RACES_TRAIN` en formato `json` alojados en un **Object Storage Público** e insertarlos en una nueva Tabla `F1_RACES_TRAIN` en el esquema ADMIN.
![img](./img/11-run.png)
Una vez que termine el job, veremos un cuadro de confirmación:
![img](./img/12-done.png)
Finalmente con el mismo usuario ADMIN, vamos a verificar la tabla que se creó en el ADW. Para ello desde el `> Development` seleccionamos `SQL`.
![img](./img/13-sql-development.png)
Allí vemos a la izquierda la tabla `F1_RACES_TRAIN`.
![img](./img/14-table-check.png)
Podemos hacer un preview de la tabla con:
```sql
SELECT
*
FROM
F1_RACES_TRAIN
```![img](./img/15-view-table.png)
Esta tabla `F1_RACES_TRAIN` fué el producto de funcionar otros sets de datos de Fórmula 1 y hacer Ingeniería de Atributos, y ese contexto es susuficiente para nuestro objetivo, en este sentido si quieres todos los detalles como un opcional después de terminar la carrera, el link se encuentra al final de este documento.
Principalmente debes saber, que:
- Cada `fila` respresenta todos los datos de una carrera.
- Nuestro **TARGET** será el `SCORE`, que representa que tan "buena" fué la experiencia según una encuesta a los aficionados y será lo que queremos predecir.Es decir, en base a los otras columnas(features) de cada fila nuestro(s) algoritmo(s) "aprenderá(n)" a predecir el SCORE, el cuál es un valor numérico continuo y será un tipo de entrenamiento supervisado, una regresión.
En la siguiente vuelta necesitaremos usar al usuario `F1`, y como la tabla `F1_RACES_TRAIN` la creamos desde el usuario **ADMIN**, entonces, debemos otogar permisos de lectura al usuario **F1**, por lo tanto, ubicados en la misma pantalla borramos el Query anterior y ejecutamos el siguiente:
```sql
GRANT ALL ON F1_RACES_TRAIN TO F1
```
![img](./img/15.1-grant-all.png)Finalmente, buscaremos el link que le compartiremos al usuario**F1** seleccionado `Oracle Machine Learning` en el apartado del `> Development`.
![img](./img/16-link-ml.png)
Y en la siguiente pantalla debemos logear como usuario **F1**.
![img](./img/17-login-f1.png)
## 3. Crear un Experimento de Auto Machine Learning (Auto-ML)
Ahora, llegó el momento de hacer Auto ML!
Recordando que ahora estamos con el usuario **F1** Iniciaremos creando un `AutoML Experiments`:
![img](./img/18-experimento.png)
Damos click en el botón `+ Create`:
![img](./img/19-new-experiment.png)
Seleccionamos:
- Name: Argentina Grand Prix
- Data Source: ADMIN.F1_RACES_TRAIN
- Predict: SCORE
- Prediction Type: Regression
- Case ID: RACEID![img](./img/20-experiment.png)
En Additional Settings seleccionaremos las siguientes opciones:
![img](./img/21-adidtional-settings.png)
El más importante es la Métrica debemos seleccionar `Median Absolute Error (MAE)`, el cual es un indicador de la imprecisión que puede llegar a tener nuestros modelos.
"Por ejemplo, si el modelo predice 100 y tenemos un MAE de 2, significa que el modelo el valor "real" podría ser 102 o 98."
En cuanto a las Features, debes selccionar solo las que están marcadas:
![img](./img/22-config-automl.png)
Regresamos al inicio de la página y guardamos nuestro expermiento:
![img](./img/23-save-automl.png)
## 4. Iniciar Entrenamiento
El siguiente paso es iniciar el experimento con los resultados más rápidos.
![img](./img/24-save-start.png)
Y estár atentos a que el entrenamiento termine:
![img](./img/25-finish-entrenamiento.png)
## 5. Encontrar el top 3 de atributos más importantes [FINAL]
Desplegamos la pestaña de Features:
![img](./img/26-end.png)
Vemos que le más importante fue:
1. F1DATE
2. CIRCUITOREF
3. DNF_DUE_TO_ACCIDENT_COUNT![img](./img/final.jpg)
## Nota Final
Este laboratorio fue diseñado a partir los [LiveLabs](https://apexapps.oracle.com/pls/apex/r/dbpm/livelabs/home?session=111942316258990) en [Learn Analytics and Machine Learning with Red Bull Racing](https://apexapps.oracle.com/pls/apex/r/dbpm/livelabs/view-workshop?wid=909&clear=RR,180&session=111942316258990)