/** * Copyright (C) 2018 Adrien Hopkins * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ package unitConverter.dimension; /** * All of the dimensions that are used by the SI. * * @author Adrien Hopkins * @since 2018-12-11 * @since v0.1.0 */ public final class StandardDimensions { // base dimensions public static final UnitDimension EMPTY = UnitDimension.EMPTY; public static final UnitDimension LENGTH = UnitDimension.getBase(SIBaseDimension.LENGTH); public static final UnitDimension MASS = UnitDimension.getBase(SIBaseDimension.MASS); public static final UnitDimension TIME = UnitDimension.getBase(SIBaseDimension.TIME); public static final UnitDimension ELECTRIC_CURRENT = UnitDimension.getBase(SIBaseDimension.ELECTRIC_CURRENT); public static final UnitDimension TEMPERATURE = UnitDimension.getBase(SIBaseDimension.TEMPERATURE); public static final UnitDimension QUANTITY = UnitDimension.getBase(SIBaseDimension.QUANTITY); public static final UnitDimension LUMINOUS_INTENSITY = UnitDimension.getBase(SIBaseDimension.LUMINOUS_INTENSITY); public static final UnitDimension INFORMATION = UnitDimension.getBase(OtherBaseDimension.INFORMATION); public static final UnitDimension CURRENCY = UnitDimension.getBase(OtherBaseDimension.CURRENCY); // derived dimensions without named SI units public static final UnitDimension AREA = LENGTH.times(LENGTH); public static final UnitDimension VOLUME = AREA.times(LENGTH); public static final UnitDimension VELOCITY = LENGTH.dividedBy(TIME); public static final UnitDimension ACCELERATION = VELOCITY.dividedBy(TIME); public static final UnitDimension WAVENUMBER = EMPTY.dividedBy(LENGTH); public static final UnitDimension MASS_DENSITY = MASS.dividedBy(VOLUME); public static final UnitDimension SURFACE_DENSITY = MASS.dividedBy(AREA); public static final UnitDimension SPECIFIC_VOLUME = VOLUME.dividedBy(MASS); public static final UnitDimension CURRENT_DENSITY = ELECTRIC_CURRENT.dividedBy(AREA); public static final UnitDimension MAGNETIC_FIELD_STRENGTH = ELECTRIC_CURRENT.dividedBy(LENGTH); public static final UnitDimension CONCENTRATION = QUANTITY.dividedBy(VOLUME); public static final UnitDimension MASS_CONCENTRATION = CONCENTRATION.times(MASS); public static final UnitDimension LUMINANCE = LUMINOUS_INTENSITY.dividedBy(AREA); public static final UnitDimension REFRACTIVE_INDEX = VELOCITY.dividedBy(VELOCITY); public static final UnitDimension REFLACTIVE_PERMEABILITY = EMPTY.times(EMPTY); public static final UnitDimension ANGLE = LENGTH.dividedBy(LENGTH); public static final UnitDimension SOLID_ANGLE = AREA.dividedBy(AREA); // derived dimensions with named SI units public static final UnitDimension FREQUENCY = EMPTY.dividedBy(TIME); public static final UnitDimension FORCE = MASS.times(ACCELERATION); public static final UnitDimension ENERGY = FORCE.times(LENGTH); public static final UnitDimension POWER = ENERGY.dividedBy(TIME); public static final UnitDimension ELECTRIC_CHARGE = ELECTRIC_CURRENT.times(TIME); public static final UnitDimension VOLTAGE = ENERGY.dividedBy(ELECTRIC_CHARGE); public static final UnitDimension CAPACITANCE = ELECTRIC_CHARGE.dividedBy(VOLTAGE); public static final UnitDimension ELECTRIC_RESISTANCE = VOLTAGE.dividedBy(ELECTRIC_CURRENT); public static final UnitDimension ELECTRIC_CONDUCTANCE = ELECTRIC_CURRENT.dividedBy(VOLTAGE); public static final UnitDimension MAGNETIC_FLUX = VOLTAGE.times(TIME); public static final UnitDimension MAGNETIC_FLUX_DENSITY = MAGNETIC_FLUX.dividedBy(AREA); public static final UnitDimension INDUCTANCE = MAGNETIC_FLUX.dividedBy(ELECTRIC_CURRENT); public static final UnitDimension LUMINOUS_FLUX = LUMINOUS_INTENSITY.times(SOLID_ANGLE); public static final UnitDimension ILLUMINANCE = LUMINOUS_FLUX.dividedBy(AREA); public static final UnitDimension SPECIFIC_ENERGY = ENERGY.dividedBy(MASS); public static final UnitDimension CATALYTIC_ACTIVITY = QUANTITY.dividedBy(TIME); // You may NOT get StandardDimensions instances! private StandardDimensions() { throw new AssertionError(); } }