001// Copyright (c) FIRST and other WPILib contributors. 002// Open Source Software; you can modify and/or share it under the terms of 003// the WPILib BSD license file in the root directory of this project. 004 005package edu.wpi.first.wpilibj.simulation; 006 007/** A utility class to simulate the robot battery. */ 008public final class BatterySim { 009 private BatterySim() { 010 // Utility class 011 } 012 013 /** 014 * Calculate the loaded battery voltage. Use this with {@link RoboRioSim#setVInVoltage(double)} to 015 * set the simulated battery voltage, which can then be retrieved with the {@link 016 * edu.wpi.first.wpilibj.RobotController#getBatteryVoltage()} method. 017 * 018 * @param nominalVoltage The nominal battery voltage. Usually 12v. 019 * @param resistanceOhms The forward resistance of the battery. Most batteries are at or below 20 020 * milliohms. 021 * @param currents The currents drawn from the battery. 022 * @return The battery's voltage under load. 023 */ 024 public static double calculateLoadedBatteryVoltage( 025 double nominalVoltage, double resistanceOhms, double... currents) { 026 double retval = nominalVoltage; 027 for (var current : currents) { 028 retval -= current * resistanceOhms; 029 } 030 return Math.max(0.0, retval); 031 } 032 033 /** 034 * Calculate the loaded battery voltage. Use this with {@link RoboRioSim#setVInVoltage(double)} to 035 * set the simulated battery voltage, which can then be retrieved with the {@link 036 * edu.wpi.first.wpilibj.RobotController#getBatteryVoltage()} method. This function assumes a 037 * nominal voltage of 12v and a resistance of 20 milliohms (0.020 ohms) 038 * 039 * @param currents The currents drawn from the battery. 040 * @return The battery's voltage under load. 041 */ 042 public static double calculateDefaultBatteryLoadedVoltage(double... currents) { 043 return calculateLoadedBatteryVoltage(12, 0.02, currents); 044 } 045}