Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/finnspartronics/pythia
(WIP) A tool for looking at FRC scouting data
https://github.com/finnspartronics/pythia
first-robotics-competition scouting
Last synced: 3 months ago
JSON representation
(WIP) A tool for looking at FRC scouting data
- Host: GitHub
- URL: https://github.com/finnspartronics/pythia
- Owner: FinnSpartronics
- License: mit
- Created: 2024-06-19T16:03:42.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-09-08T20:17:08.000Z (4 months ago)
- Last Synced: 2024-09-26T13:41:18.088Z (3 months ago)
- Topics: first-robotics-competition, scouting
- Language: JavaScript
- Homepage:
- Size: 82 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Pythia
This tool isn't intended to help with the collection of data,
but rather to help teams look at the data they've collected with the help of other tools.## 1. APIs
### 1.1 What is an API?
This tool makes use of a few APIs, which are basically websites that store a collection of data that other websites or apps, like this one, can access at any time.| API | A brief explanation | Features that depend on this API |
| ---- | ---- | ---- |
| The Blue Alliance | TBA is a collection of a bunch of data on the First Robotics Competition (FRC). This is used for data on each team, and the event as a whole. | Team names and information other than icon and number, Event-specific information, |
| The Blue Alliance (Matches) | This is part of the above API, but can be disabled even while using the main API. It requires that the above is enabled for this one to be enabled. This is used for data on individual matches that each team is a part of. | Team winrate calculations, as well as matches, what alliance a team was on, who they were with, and who they were against. |
| Desmos | Desmos is an amazing online graphing calculator with a plethora of features. | Graphs of team data |
| FRC Colors | FRC Colors has information on most team's primary and secondary colors, but they also host a copy of each of those teams' icons, which is what this tool uses FRC Colors for. | Team icons |### 1.2 The Blue Alliance API Key
You'll need to provide your own API key for The Blue Alliance, which can be obtained by following the following steps:
1. Go to https://www.thebluealliance.com/account and create an account or sign in
2. Scroll down to **Read API Keys**
3. Type anything in the field for **Description**. I suggest something like "Scouting Analysis", but its up to you.
4. Press **+ Add New Key**
5. The page will reload, and you need to scroll back down to **Read API Keys**, where you can now copy the odd string of text and numbers underneath **X-TBA-Auth-Key**Now that you have your API key, return to Pythia, press the **APIs** button at the top of the screen, and then **Set TBA API Key**.
You will be prompted for your API Key. Paste it in the pop-up, and then press enter or the confirmation button. This will be automatically saved in your browser for future sessions.If you are prompted with the lack of a TBA API key, follow the previous instructions to (if needed) obtain one, and re-paste it into the tool.
### 1.3 Enabling and Disabling APIs
If Pythia encounters a strange error, you may want to enable or disable an API.
They can be toggled on or off in the **APIs** menu at the top of the screen.## 2. Event and Year
Event and Year settings will not apply if TBA API is disabled.
### 2.1 Event
You can set what event you are looking at by finding whatever your event code is, for example:WABON - PNW District Bonney Lake Event,
and typing that event code into the **Set Event** button located inside of the **Event** menu.
If you have previously entered an event, the **Set Event** button will instead show the event code for that previous event.### 2.2 Year
When you first load Pythia, the year will be assumed based on the current year,
but you can change the year by going into the **Event** menu and clicking on the year button, which will display whatever the currently selected year is.## 3. Data and Data Mappings
You've now reached the part that this whole tool is made for, the data.
I recognize that all teams have their unique scouting data tools, formats, and everyone looks for different things in what they want.
This tool should fit most team's needs, but if you want more features, please suggest them in a Github Issue.### 3.1 Data
Accepted formats for scouting data are in the form of .csv files, and in the form of .json files.Note: .CSV files will be automatically converted into JSON, so if you later choose to download your data from the tool it may be in a different format from what you originally had.
Data needs to be in the form of individual scouting submissions, for example:
```json
[
{
"Team": 4915,
"Match Number": 52,
"Notes/Comments": "This is an example note/comment",
"Your Name": "John Doe",
"Points scored": 17
}
]
```
or, in CSV format:
```csv
"Team","Match Number","Notes/Comments","Your Name","Points scored"
"4915","52","This is an example note/comment","John Doe","17"
```JSON data must not have any further objects in the fields, for example, you cannot do something like:
```json
"Points scored": {
"Speaker Points": 5,
"Amp Points": 2
}
```Field names can be whatever you would like them to be, as will be explained in the next section on data mappings,
but there must be the following four bits of data in some form or another:
- Team
- Their team number, for example, 4915
- Their team number proceeded by frc, for example, frc4915,
- Their team name, for example, Spartronics (Not suggested)
- Match number
- Notes/Comments
- Should be a string containing comments on that individual team's performance during that match.
- Scouter's Name
- Should be a string with the name of whoever scouted that team during that match.
- Likely will not be a requirement in future versions
To put your data into the tool, open the **File** menu at the top of the screen, and press **Import Data**.
You will be prompted for the file that contains your scouting data. It will automatically be saved for future sessions.### 3.2 Data Mappings
So, the tool has your data, but it doesn't really know what to do with it. That's where data mappings come in.
Data mappings tell the tool what to do with your data.This is the most complicated part of the tool, but once it is set up for a season it likely will not need to be changed.
#### 3.2.1 Data Mapping Format
Data mappings are stored in JSON files.Here is an empty template for a data mapping:
```json
{
"team": "",
"match": {
"number": ""
},
"notes": "",
"scouter": "",
"mapping_version": 1,
"averages": {},
"calculated": {},
"calculated_averages": {},
"graphs": {}
}
```How this works is there is the field on the left, for example, "notes", and then whatever is on the right is the key for that bit of data in the scouting data.
For example, if your data looked like this:
```json
[
{
"Team": 4915,
"Match Number": 52,
"Notes/Comments": "This is an example note/comment",
"Your Name": "John Doe",
"Points scored": 17
}
]
```
Your mapping would look like this:
```json
{
"team": "Team",
"match": {
"number": "Match Number"
},
"notes": "Notes/Comments",
"scouter": "Your Name",
"mapping_version": 1,
"averages": {},
"calculated": {},
"calculated_averages": {},
"graphs": {}
}
```#### 3.2.2 Team Format
"team" may be in either of two formats:
```json
{
"team": {
"key": "",
"format": ""
},
"team": ""
}
```
The first one is preferred. In that case, you would put the key for where the team is in your scouting data in the "key" field.
Then, you would put one of the following three options in the "format" field.| Format | When to use |
| ---- | ---- |
| # | When the team is represented by their team number in your scouting data, for example, 4915 |
| frc# | When the team is represented by their team number preceded by "frc" in your scouting data, for example, frc4915 |
| name | When the team is represented by their team name in your scouting data, for example, Spartronics. This option is not recommended due to the easy chance of typos and mismatches |If you use the second format for "team", just put the key in that spot. The format will automatically be detected.
NOTE: If you use the name format for your scouting data, The Blue Alliance API is required, and Pythia will not work when you turn TBA off.
#### 3.2.2 Custom Table Columns
So, how do you get your data onto the table? Thats where averages, calculated, and calculated_averages come in handy.
| Type | What it does |
| ---- | ---- |
| averages | Takes the average of that key for all matches in a team
| calculated | Adds up all of some calculations for all matches in a team |
| calculated_averages | Takes the average of some calculations for all matches in a team |Lets start with averages first. Like above with stuff like "scouter" or "notes", you just put in the key for whatever data you want to be averaged.
But what do you put first? JSON format works on a `key: value` system, so you can't just put the key for what you want.
Well, first you put the name of the table column.For example, if the name of your key in your data was "Auto amp notes scored", you could do anything like this, or come up with your own:
```json
{
"averages": {
"Auto amp notes scored": "Auto amp notes scored",
"Auto amp notes": "Auto amp notes scored",
"Amp (Auto)": "Auto amp notes scored"
}
}
```
The column that would show up on the table would be whatever is on the left, and the data comes from whatever is on the right.#### 3.2.3 Calculations (Calculated and Calculated Averages)
The next two work in a similar way, but allow you to do calculations with multiple parts of data.
The calculation format is kinda weird. To start, there are the following operations:
> Addition +
>
> Subtraction -
>
> Multiplication *
>
> Division /
>
> Power ^, pow
>
> Equality =Most of these are self-explanatory, except for equality.\
Lets say that you have `a = b`. How this would work is if a is equal to b, then it would simplify to the number 1. Meanwhile, if a is not equal to b, it would evaluate to zero.So, how do you use these operations in calculations? Lets use this example where a team's scouting data might have two separate fields for auto amp notes and teleop amp notes.
```json
{
"calculated": {
"Total Amp Notes": ["Auto Amp Notes", "+", "Teleop Amp Notes"]
}
}
```
You just create a JSON array with three items in it, the first being a, the second being the operation, and the third being b. `a +-*/^= b`You can also stack these together, for example the following which could add up to see the average amount of notes a team played.
```json
{
"calculated_averages": {
"Total Notes": [["Auto Amp Notes", "+", "Teleop Amp Notes"], "+", ["Auto Speaker Notes", "+", "Teleop Speaker Notes"]]
}
}
```
Order of operations is not an issue, because each array is pretty much just parenthesis around that specific calculation.Notice how this time "calculated_averages" is used. Both calculated_averages and calculated use the same syntax for calculations.
The only difference is that calculated_averages takes the average (mean) of the numbers.You can also replace one of these key strings with a number, for example in the above example, `"Auto Amp Notes"` could have been replaced with `5`.
There are also some functions included that can be used in your calculations.
> abs\
> sin\
> cos\
> tan\
> asin\
> acos\
> atan\
> floor\
> ceil\
> log10\
> round\
> sign\
> sqrt\
> cbrtThe syntax for these functions is as follows:
`[function, a]`
where function is a string with the function name, and a is either a number, or another expression.You can also use "pi" or "e" anywhere in your calculations.
If you want to, you can also have an 1 item array with just a key inside, for example: `["Auto amp notes scored"]`. This may be useful for graphs.
#### 3.2.4 Graphs
Graphs use the same syntax as calculated and calculated averages, but the data will be displayed in graph form on a team page instead of on the main table.
Simply put your calculation in the "graphs" area like you would for calculated or calculated_averages
#### 3.2.5 Example of a finished mapping
Here is an example of a finished data mapping. Please note that this is only for example use, and your mapping will most likely be very different from this.
```json
{
"team": "Team Number",
"match": {
"number": "Match number"
},
"notes": "Other thoughts/Summary",
"scouter": "Your Name",
"mapping_version": 1,
"averages": {
"Rating": "Overall subjective ranking",
"Bot Rating": "Bot rating",
"Drive Rating": "Drive team rating"
},
"calculated": {
"Total Amp Notes": ["Auto Amp Notes Scored","+","Amp notes scored"]
},
"calculated_averages": {
"Av. Amp Notes": ["Auto Amp Notes Scored","+","Amp notes scored"],
"Scouting Winrate": ["Result","=","Win"],
"Av. Points": [[[["Auto Speaker Notes Scored","*",5],"+",["Non amplified speaker notes scored","*",2]],"+",[["Auto Amp Notes Scored","*",2],"+","Amp notes scored"]],"+",["Amplified speaker notes scored","*",5]]
},
"graphs": {
"Points scored": [[[["Auto Speaker Notes Scored","*",5],"+",["Non amplified speaker notes scored","*",2]],"+",[["Auto Amp Notes Scored","*",2],"+","Amp notes scored"]],"+",["Amplified speaker notes scored","*",5]],
"Notes scored (Teleop)": [["Amp notes scored", "+", "Non amplified speaker notes scored"], "+", "Amplified speaker notes scored"]
}
}
```#### 3.2.6 Putting your mapping into Pythia
To put your mapping file into the tool, follow the following instructions.
1. Open the **File** menu
2. Press **Import mapping**
3. Select your mapping file
Your mapping will be saved in the browser for future use.
### 3.3 Downloading saved data or mappings
You can also download your saved data or mappings in case you lose the original files. Please note that sometimes the browser may glitch and lose your saved data.Download your saved data or mapping by opening the **File** menu and pressing the button for whatever you want to download.
If you do not have saved data or mappings, the respective button will be grayed out.## 4. Navigation
### 4.1 Navigating the Table
Navigating the table is like a normal spreadsheet. Scroll to the left or right to see more in that direction, or scroll up and down to see that information.### 4.1.1 Sorting the table
By tapping on one of the columns on the table header, you will change the way the table is sorted.\
The currently active column on the table is marked by a different background color on the header cell.\### 4.1.2 Reordering and toggling table columns
### 4.1.3 Starring teams
### 4.2 Team Pages