Skip to content
This repository has been archived by the owner on Nov 23, 2024. It is now read-only.

Latest commit

 

History

History
54 lines (44 loc) · 2.8 KB

README.md

File metadata and controls

54 lines (44 loc) · 2.8 KB

Spartan Racing BMS R&D Repository

A senior project with a goal to produce an in-house BMS using the LTC6813 to support a 600V pack, as well as analysis software to view cell data and configure the BMS.

Project Demonstration

YouTube Video of Project Demo

Project Folder Structure

  • altium/ : Altium Designer project files for the custom BMS master and slave PCB (schematic & layout)
  • doc/ : Supplementary documentation, mostly hardware-related (like datasheets)
  • examples/ : Firmware examples for the BMS master, various programs.
    • The primary example that was utilized was stm32f105_isospi
  • gui/ : GUI Analysis Software for the host computer , to visualize battery cell data and communicate with the BMS master PCBA.
  • media/ : Various photos and such

Environment Setup

Version Control

  1. Install git (Windows)
  2. Clone this repo into any reachable folder using, in a command line of your choice (WSL Ubuntu, PowerShell, Terminal, etc), git clone https://github.com/spartanracingelectric/SR-BMS.git
    1. Change your branch if necessary by using git checkout <BRANCH_NAME>

Altium Designer PCB Design Setup

Simple, just open either the master or slave .PrjPcb files in Altium!

Firmware Setup

  1. Install STM32CubeIDE and STM32CubeProgrammer.
  2. In STM32CubeIDE, import the projects from examples/.
  3. In STM32CubeIDE, click the "build" hammer on the toolbar to compile/build one of the programs in examples/.
  4. In STM32CubeProgrammer, flash the .elf binary generated in the specific example project's Debug/ to the BMS master PCBA over ST-Link or USB.
  5. Note: STM32CubeMX to make any initialization-level configuration changes for the microcontroller.

GUI Setup

  1. cd gui/bms_app
    • install necessary react scripts using 'npm install react-scripts'
  2. Backend and frontend must be run concurrently
    • frontend: open terminal in bms_app folder use: 'npm start'
    • backend: open terminal in serialcomm folder 'npm run dev'
    • backend deals w/ serial communication. Ensure that the correct COM port is defined in server.js!
    • to view the backend use the url: "http://localhost:8000/graphdata"

SR BMS R&D Senior Project Team

Vincent Saw, Ex-Software Lead for Spartan Racing, Firmware & Hardware & Integration
Vincent Pham, Project Member, Firmware & Hardware
Josh Samoy, Project Member, Firmware & Software
Abegail Palad, Project Member, Firmware & Software

Links

Primary Repo for BMS Senior Project
Old GUI Analysis Software Repo
Spartan Racing Website