| You are not Logged In! | 
Difference between revisions of "Public:Electrical Onboarding Fall 2023"
| m (updating a bit) | m (Gvi2 moved page Electrical Onboarding Fall 2023 to Public:Electrical Onboarding Fall 2023 without leaving a redirect: Moved to Public Namespace) | 
Revision as of 09:56, 24 August 2023
Welcome to Illini Solar Car! We are glad you’re here!
Illini Solar Car is one of the largest engineering projects on campus. Our work is incredibly multifaceted (there are even times when you’ll be working on two cars simultaneously), diverse in majors and members, expensive (we go through 6 figures of resources per year), and rewarding. You can think of all the expenses as an investment in you as they provide you with unmatched real-world and hands-on experience which can be invaluable when looking for jobs or when you eventually get to doing it later in school.
Due to the scope of this project, the team does have a somewhat large learning curve. In order to help with this learning curve we introduced this wiki in Spring 2018 to put what institutional knowledge we have in an accessible location as opposed to only being in peoples heads. Older members will certainly help you to learn (especially with hands-on and technical skills) but we also expect you to be able to pick up on background from the wiki and be proactive about learning about the team. Perusing this wiki should help you do so. It will also help you become familiar with the team and how we operate. The contents of this page should serve as an overview of the Fall 2023 onboarding process and some useful getting started info.
You will notice that even though there are already 5 years' worth of information on this site, there are always new pages being added and updated. As you are learning things please feel free to contribute! Additionally, if there is valuable info you feel is missing please add it to the ((Wanted Content|Wanted Pages)) list.
This page is created to integrate all the electrical onboarding links onto a single page and help provide a hub for the onboarding process. In general, there will be 4 methods of accessing all the electrical team's information for onboarding:
- Slack (Please check regularly)
- GitHub
- Google Drive
- Wiki (You're already here!)
Each of these sites host information on events and meetings, or important files from testing, building past cars, etc. Please check these to stay updated and learn more about the team!
Planned Dates/ Deadlines
Most of Fall 23 Onboarding will be done in-person at onboarding meetings, so new members will have the chance to receive guidance from older team members if they need extra help during the process. However, a majority of onboarding can be done by following the guidelines and tutorials set up later on in this page. Below is a general outline of when and where meetings will be. Make sure to show up to these and other new member events to get to know your seniors and get comfortable with your team!
Meeting Days & Times: Mondays & Wednesdays @ 7:00 PM (Tentative)
Location: Openlab, 1015 ECE Building (306 N Wright St)
Onboarding weeks: 4th September - 29th October (Tentative)
During this time you will be doing three projects that will teach you important knowledge and skills to have on the electrical team.  They'll be split up with one week each to the first two projects, and the last two weeks will be spent doing a harder project of your choice.  Each of these projects will be detailed here, with links to relevant pages that you will need to properly do the work.  To begin, you'll need to set up a few accounts and download some apps.  See below.
Please complete the setup of GitHub, KiCad, and MCUXPresso before the first onboarding meeting. If you have any questions, ask them in a Slack Public Channel. We use public channels because you are likely not the only person to have this question. If you are still stuck, you can ask us at the first meeting.
GitHub Setup
GitHub is a tool we use to share all of our work as a team. It is a great way to ensure all the current work stays updated and there are very little conflicts when working together. Most industry professionals use GitHub for code, however we also use it with our KiCad projects as well as code. You may be familiar with the GitHub site, but not so much with our use of Git Bash, so there are a few resources here to help you get familiar. Git is hard to learn so don't be upset if you don't understand how it works at the end of onboarding, you'll get more practice and become a pro later :)
Be aware that you may or may not have access to the ISC GitHub right away. We will have a form sent out in early onboarding days to get everyone access, but if you still have trouble joining later there will be a channel for questions on the Onboarding Slack.
- Go to the GitHub wiki page and ensure you have a working version of Git on your computer. Look through the Installing Git section of the page. Make sure you have the most recent version of Git!
- Look through Jarod's git youtube tutorials to get a better understanding of why we use git as well as a few basic commands
- If you'd like more practice with Git, checkout these other interactive tutorials to learn more:
- Interactive tutorial: https://try.github.io/
- Git Branching: https://learngitbranching.js.org/
 
This part is important to getting a good feel of our workflow. Proper push/pull form helps keep our work space clean!
KiCad Setup
KiCad is an electrical CADing software that our team uses to design the custom printed circuit boards (aka PCBs) for the solar car. All of our designs exist on the Illini Solar Car GitHub page in the PCB repository. You will clone this repository later and any hardware contribution you make to the team will be in here forever :)
- First download KiCad onto your computer from here, use the most recent stable version available.
- Next clone the Onboarding repository.
- Use cdto move to the location you want your Repository to go, I would recommend either the Desktop or Documents
- Run git clone https://github.com/IlliniSolarCar/ElecOnboarding23.gitin either GitBash (Windows) or Terminal (MacOS) to clone the repository to your local machin
- If you still have issues, follow the Initial Setup instructions here. (The page is setup for using the PCB repository. Don't use that! We are using the new Onboarding repo this year for an easier work space. Please follow all the instructions but use the Onboarding repository instead.)
 
- Use 
- Setup KiCad by following the KiCad First Time Setup instructions.
- Note: We use KiCad v7. If there are any files in the future that are in previous versions, just save them as v7. Anything v5 and below will have a libraries issue that can be resolved by copy/pasting the lib files from a v7 project into that folder.
 
After Completing Setup
- Create a Branch in the Onboarding Repository, this branch will be exclusive to you.
- Run git checkout -b jdoe2_onboarding(replace jdoe2 with your netid [your illinois email without the @illinois.edu]) to create the branch
- Run git statusto ensure you are on the correct branch
- Run git push --set-upstream origin jdoe2_onboardingto push your new branch to the remote repository
 
- Run 
- Start working on the Onboarding Projects! We created a series of projects to act as goals to progress yourselves with KiCad. We have 1 required project and one harder one for you to choose from as your third project. You are required to complete at least one advanced project, either hardware or firmware. We'll be there to help you, so don't worry about the projects being too hard, just do your best!
- While working on the onboarding projects take a look at these useful guidelines.
- KiCad Schematic Conventions - has information about specifics regarding each part of the schematic design from naming conventions to symbol creation to part selection
- KiCad Layout Standards - has information about the design guidelines for PCBs and illustrates what is allowed and what isn't
 
- After Completing the schematic for your first onboarding project push your work to the Onboarding repository using your git knowledge
- Don't worry that you're not done yet, pushing is for us to see that you're making progress!
 
- Finish the layout and push the changes to your branch to get more feedback. Our senior members will be reviewing and approving everything you push, so keep an eye on your branch for any comments your leads may have.
- You're done! Use all this knowledge for any of the hardware projects you do in the future.
MCUXPresso Setup
In order to control our various hardware components, we write firmware code to allow various processes to happen. For example if the brake is pressed, we have a hall effect-sensor that gets triggered which sends an enable signal to our Dash in order to turn on the brake lights. All of our firmware is written in C++ and we use MCUXpresso, an eclipse based IDE.
- Go through the MCUXpresso setup instructions. Don't worry about setting up ARGO-fw or b-fw as we are using the onboarding Repository..
- B-fw is the old firmware repo for Brizo. We won't be using it for the onboarding process nor for our third car, but it's good to have in case we are still testing on Brizo by the time Onboarding finishes!
- All of the coding that you do for Onboarding will be pushed to the Onboarding repo. Don't worry about pushing to the others for now.
- Make sure to double click on update_LibraryProjectFiles.shto get the projects to work in MCUXPresso
 
- Follow the Building and Debugging Code instructions to ensure you are able to setup the project files and build the skeleton code. For the Flashing/Debugging Section: we'll work on getting that situated as you get your firmware project closer to being completed.
- Most likely, you will learn this through watching members and looking it up on your own for another project down the line. Don't be afraid to ask for help!
 
After Completing Setup
- As stated above, we have a few firmware projects on this page for you to do. One will be a required firmware project that's easier, and the other will be an optional advanced project to choose from between hardware and firmware.
- Here are some links to get you more familiar with firmware:
- Firmware Standards
- Basics of C++
- Basics of Communications Protocols
 
Onboarding Projects
Below will be the projects for each of the hardware and firmware groups.
You are required to finish the easy projects for both firmware and hardware in the first two weeks of onboarding before choosing one harder project from either firmware or hardware to complete in the last two weeks of onboarding. This is the criteria to complete your technical introduction to ISC and you will not be able to join the club if you do not finish!
Team leadership and senior members will be happy to help and answer questions, so be sure to use the onboarding meetings as time to discuss any issues you have in person.
On top of that, you may have to work on these projects outside of team meetings! This is standard within solar car; not all of our work is done during the two times a week that we meet. Don't worry if it takes you extra time to work on these projects.
Firmware
Project 1: Heartbeat LEDs
This project...
(Hard) Project 2: Find the Bugs
Hardware
Hardware is much more tedious than firmware. When it comes to schematic design and layout, datasheets are a critical part of the project, which is why we use PartsBox to organize our part inventory and store all relevant information. These projects will get you used to the KiCad software as well as our typical process of researching datasheets, creating BOMs, generating DFMs, etc. These are all integral parts of the solar car PCB design flow!
Project 1: LED Circuit
This project is relatively simple: in order to get used to the KiCad application and a few of its typical shortcuts, you'll build an LED circuit in the schematic editor before laying it out. Ryder has made a few videos on youtube to walk through the process, but here are the steps written out:
- Make sure you have KiCad v7 downloaded. You'll have a hard time opening any files if you don't.
- In your File Explorer, you'll want to navigate to the folder you copied the Onboarding Repo into (make sure that you copied the Onboarding Repo when setting up Git rather than the B-fw or PCB repos).
- In the _______ folder, you should.... [Insert how to make a new project and use the Solar Car templates Ryder made]
- [insert how to start the schematic using Add Component and grab all the parts first]
- [get the datasheets and values of all parts into the big parts manager]
- [how to hook up wires and the shortcuts relevant]
- [rate the parts for the correct amount of voltage and current, add a fuse if needed to make the circuit harder]
- [run the annotation device and the debugger]
- [make sure all parts work in the circuit before exporting netclass]
- [layout design]
- [export all relevant stuff]
- [dfm]
- [done]