public string ToString(MolarMassUnit unit, [CanBeNull] string cultureName, int significantDigitsAfterRadix) { double value = As(unit); string format = UnitFormatter.GetFormat(value, significantDigitsAfterRadix); return(ToString(unit, cultureName, format)); }
public string ToString(MolarMassUnit unit, [CanBeNull] IFormatProvider provider, int significantDigitsAfterRadix) { double value = As(unit); string format = UnitFormatter.GetFormat(value, significantDigitsAfterRadix); return(ToString(unit, provider, format)); }
public static string GetAbbreviation(MolarMassUnit unit, [CanBeNull] string cultureName) { // Windows Runtime Component does not support CultureInfo and IFormatProvider types, so we use culture name for public methods: https://msdn.microsoft.com/en-us/library/br230301.aspx IFormatProvider provider = cultureName == null ? UnitSystem.DefaultCulture : new CultureInfo(cultureName); return(UnitSystem.GetCached(provider).GetDefaultAbbreviation(unit)); }
// Windows Runtime Component does not support nullable types (double?): https://msdn.microsoft.com/en-us/library/br230301.aspx #if !WINDOWS_UWP /// <summary> /// Dynamically convert from value and unit enum <see cref="MolarMassUnit" /> to <see cref="MolarMass" />. /// </summary> /// <param name="value">Value to convert from.</param> /// <param name="fromUnit">Unit to convert from.</param> /// <returns>MolarMass unit value.</returns> public static MolarMass?From(QuantityValue?value, MolarMassUnit fromUnit) { if (!value.HasValue) { return(null); } return(new MolarMass((double)value.Value, fromUnit)); }
/// <summary> /// Creates the quantity with the given numeric value and unit. /// </summary> /// <param name="value">The numeric value to construct this quantity with.</param> /// <param name="unit">The unit representation to construct this quantity with.</param> /// <remarks>Value parameter cannot be named 'value' due to constraint when targeting Windows Runtime Component.</remarks> /// <exception cref="ArgumentException">If value is NaN or Infinity.</exception> private MolarMass(double value, MolarMassUnit unit) { if (unit == MolarMassUnit.Undefined) { throw new ArgumentException("The quantity can not be created with an undefined unit.", nameof(unit)); } _value = value; _unit = unit; }
/// <summary> /// Creates the quantity with the given numeric value and unit. /// </summary> /// <param name="numericValue">The numeric value to contruct this quantity with.</param> /// <param name="unit">The unit representation to contruct this quantity with.</param> /// <remarks>Value parameter cannot be named 'value' due to constraint when targeting Windows Runtime Component.</remarks> /// <exception cref="ArgumentException">If value is NaN or Infinity.</exception> private MolarMass(double numericValue, MolarMassUnit unit) { if (unit == MolarMassUnit.Undefined) { throw new ArgumentException("The quantity can not be created with an undefined unit.", nameof(unit)); } _value = Guard.EnsureValidNumber(numericValue, nameof(numericValue)); _unit = unit; }
/// <summary> /// Convert to the unit representation <paramref name="unit" />. /// </summary> /// <returns>Value converted to the specified unit.</returns> public double As(MolarMassUnit unit) { if (Unit == unit) { return(Convert.ToDouble(Value)); } var converted = AsBaseNumericType(unit); return(Convert.ToDouble(converted)); }
/// <summary> /// Convert to the unit representation <paramref name="unit" />. /// </summary> /// <returns>Value converted to the specified unit.</returns> public decimal As(MolarMassUnit unit) { if (Unit == unit) { return(Convert.ToDecimal(Value)); } var converted = AsBaseNumericType(unit); return(Convert.ToDecimal(converted)); }
10 * KnownQuantities.MolarMassOfOxygen, MassUnit.Gram)] // 10 Moles of Oxygen weight 10 times as much as 1 Mole of Oxygen (MolarMass) public void MassFromAmountOfSubstanceAndMolarMass( double amountOfSubstanceValue, AmountOfSubstanceUnit amountOfSubstanceUnit, double molarMassValue, MolarMassUnit molarMassUnit, double expectedMass, MassUnit expectedMassUnit, double tolerence = 1e-5) { AmountOfSubstance amountOfSubstance = new AmountOfSubstance(amountOfSubstanceValue, amountOfSubstanceUnit); MolarMass molarMass = new MolarMass(molarMassValue, molarMassUnit); Mass mass = amountOfSubstance * molarMass; AssertEx.EqualTolerance(expectedMass, mass.As(expectedMassUnit), tolerence); }
1026.98355, MolarityUnit.MolesPerCubicMeter)] // test from JonathanDavies626 public void MolarityFromMassConcentrationAndMolarMass( double massConcValue, MassConcentrationUnit massConcUnit, double molarMassValue, MolarMassUnit molarMassUnit, double expectedMolarityValue, MolarityUnit expectedMolarityUnit, double tolerance = 1e-5) { var massConcentration = new MassConcentration(massConcValue, massConcUnit); var molarMass = new MolarMass(molarMassValue, molarMassUnit); Molarity molarity = massConcentration.ToMolarity(molarMass); // molarity / molarMass AssertEx.EqualTolerance(expectedMolarityValue, molarity.As(expectedMolarityUnit), tolerance); }
0.625023438378939, AmountOfSubstanceUnit.Mole)] // 10 grams Of Oxygen contain 0.625023438378939 Moles public void AmountOfSubstanceFromMassAndMolarMass( double massValue, MassUnit massUnit, double molarMassValue, MolarMassUnit molarMassUnit, double expectedAmountOfSubstanceValue, AmountOfSubstanceUnit expectedAmountOfSubstanceUnit, double tolerence = 1e-5) { var mass = new Mass(massValue, massUnit); var molarMass = new MolarMass(molarMassValue, molarMassUnit); AmountOfSubstance amountOfSubstance = mass / molarMass; AssertEx.EqualTolerance(expectedAmountOfSubstanceValue, amountOfSubstance.As(expectedAmountOfSubstanceUnit), tolerence); }
4.16667, MassConcentrationUnit.KilogramPerCubicMeter)] // HCL solution public void ExpectMolarityConvertedToMassConcentrationCorrectly( double molarityValue, MolarityUnit molarityUnit, double componentMolarMassValue, MolarMassUnit compontMolarMassUnit, double expectedMassConcValue, MassConcentrationUnit expectedMassConcUnit, double tolerence = 1e-5) { var molarity = new Molarity(molarityValue, molarityUnit); var componentMolarMass = new MolarMass(componentMolarMassValue, compontMolarMassUnit); MassConcentration concentration = molarity.ToMassConcentration(componentMolarMass); // molarity * molarMass AssertEx.EqualTolerance(expectedMassConcValue, concentration.As(expectedMassConcUnit), tolerence); }
0.5, MolarityUnit.MolesPerLiter)] // 29.19419518377693 = VolumeConcentration_0_5M_Ethanol public void MolarityFromVolumeConcentrationAndComponentDensityAndMolarMass( double volumeConcValue, VolumeConcentrationUnit volumeConcUnit, double componentDensityValue, DensityUnit componetDensityUnit, double componentMolarMassValue, MolarMassUnit componentMolarMassUnit, double expectedMolarityValue, MolarityUnit expectedMolarityUnit, double tolerence = 1e-5) { var volumeConcentration = new VolumeConcentration(volumeConcValue, volumeConcUnit); var componentDensity = new Density(componentDensityValue, componetDensityUnit); var componentMolarMass = new MolarMass(componentMolarMassValue, componentMolarMassUnit); Molarity molarity = volumeConcentration.ToMolarity(componentDensity, componentMolarMass); // volumeConcentration * density / molarMass AssertEx.EqualTolerance(expectedMolarityValue, molarity.As(expectedMolarityUnit), tolerence); }
29.19419518377693, VolumeConcentrationUnit.MillilitersPerLiter)] // 0.5M ethanol public void VolumeConcentrationFromComponentDensityAndMolarity( double molarityValue, MolarityUnit molarityUnit, double componentDensityValue, DensityUnit componentDensityUnit, double componentMolarMassValue, MolarMassUnit compontMolarMassUnit, double expectedVolumeConcValue, VolumeConcentrationUnit expectedVolumeConcUnit, double tolerence = 1e-5) { var molarity = new Molarity(molarityValue, molarityUnit); var componentDensity = new Density(componentDensityValue, componentDensityUnit); var componentMolarMass = new MolarMass(componentMolarMassValue, compontMolarMassUnit); VolumeConcentration volumeConcentration = molarity.ToVolumeConcentration(componentDensity, componentMolarMass); AssertEx.EqualTolerance(expectedVolumeConcValue, volumeConcentration.As(expectedVolumeConcUnit), tolerence); }
1.2, VolumeUnit.Liter)] // 1.2 L of solution required for obtaining 0.1142805 Moles/L from 5g HCl public void VolumeSolutionFromComponentMassAndDesiredConcentration( double componentMassValue, MassUnit componentMassUnit, double componentMolarMassValue, MolarMassUnit componentMolarMassUnit, double desiredMolarityValue, MolarityUnit desiredMolarityUnit, double expectedSolutionVolumeValue, VolumeUnit expectedSolutionVolumeUnit, double tolerence = 1e-5) { var componentMass = new Mass(componentMassValue, componentMassUnit); var componentMolarMass = new MolarMass(componentMolarMassValue, componentMolarMassUnit); var desiredMolarity = new Molarity(desiredMolarityValue, desiredMolarityUnit); AmountOfSubstance amountOfSubstance = componentMass / componentMolarMass; Volume volumeSolution = amountOfSubstance / desiredMolarity; AssertEx.EqualTolerance(expectedSolutionVolumeValue, volumeSolution.As(expectedSolutionVolumeUnit), tolerence); }
0.1142805, MolarityUnit.MolesPerLiter)] // molarity(HCl) = 5g / (1.2L * 36.46) = 0.114 mol/l = 0.114 M public void MolarityFromComponentMassAndSolutionVolume( double componentMassValue, MassUnit componentMassUnit, double componentMolarMassValue, MolarMassUnit componentMolarMassUnit, double solutionVolumeValue, VolumeUnit solutionVolumeUnit, double expectedMolarityValue, MolarityUnit expectedMolarityUnit, double tolerence = 1e-5) { var componentMass = new Mass(componentMassValue, componentMassUnit); var componentMolarMass = new MolarMass(componentMolarMassValue, componentMolarMassUnit); var volumeSolution = new Volume(solutionVolumeValue, solutionVolumeUnit); AmountOfSubstance amountOfSubstance = componentMass / componentMolarMass; Molarity molarity = amountOfSubstance / volumeSolution; AssertEx.EqualTolerance(expectedMolarityValue, molarity.As(expectedMolarityUnit), tolerence); }
// Windows Runtime Component does not support nullable types (double?): https://msdn.microsoft.com/en-us/library/br230301.aspx #if !WINDOWS_UWP /// <summary> /// Dynamically convert from value and unit enum <see cref="MolarMassUnit" /> to <see cref="MolarMass" />. /// </summary> /// <param name="value">Value to convert from.</param> /// <param name="fromUnit">Unit to convert from.</param> /// <returns>MolarMass unit value.</returns> public static MolarMass?From(QuantityValue?value, MolarMassUnit fromUnit) { if (!value.HasValue) { return(null); } switch (fromUnit) { case MolarMassUnit.CentigramPerMole: return(FromCentigramsPerMole(value.Value)); case MolarMassUnit.DecagramPerMole: return(FromDecagramsPerMole(value.Value)); case MolarMassUnit.DecigramPerMole: return(FromDecigramsPerMole(value.Value)); case MolarMassUnit.GramPerMole: return(FromGramsPerMole(value.Value)); case MolarMassUnit.HectogramPerMole: return(FromHectogramsPerMole(value.Value)); case MolarMassUnit.KilogramPerMole: return(FromKilogramsPerMole(value.Value)); case MolarMassUnit.KilopoundPerMole: return(FromKilopoundsPerMole(value.Value)); case MolarMassUnit.MegapoundPerMole: return(FromMegapoundsPerMole(value.Value)); case MolarMassUnit.MicrogramPerMole: return(FromMicrogramsPerMole(value.Value)); case MolarMassUnit.MilligramPerMole: return(FromMilligramsPerMole(value.Value)); case MolarMassUnit.NanogramPerMole: return(FromNanogramsPerMole(value.Value)); case MolarMassUnit.PoundPerMole: return(FromPoundsPerMole(value.Value)); default: throw new NotImplementedException("fromUnit: " + fromUnit); } }
/// <summary> /// Parse a string with one or two quantities of the format "<quantity> <unit>". /// </summary> /// <param name="str">String to parse. Typically in the form: {number} {unit}</param> /// <param name="provider">Format to use when parsing number and unit. Defaults to <see cref="UnitSystem.DefaultCulture" />.</param> /// <example> /// Length.Parse("5.5 m", new CultureInfo("en-US")); /// </example> /// <exception cref="ArgumentNullException">The value of 'str' cannot be null. </exception> /// <exception cref="ArgumentException"> /// Expected string to have one or two pairs of quantity and unit in the format /// "<quantity> <unit>". Eg. "5.5 m" or "1ft 2in" /// </exception> /// <exception cref="AmbiguousUnitParseException"> /// More than one unit is represented by the specified unit abbreviation. /// Example: Volume.Parse("1 cup") will throw, because it can refer to any of /// <see cref="VolumeUnit.MetricCup" />, <see cref="VolumeUnit.UsLegalCup" /> and <see cref="VolumeUnit.UsCustomaryCup" />. /// </exception> /// <exception cref="UnitsNetException"> /// If anything else goes wrong, typically due to a bug or unhandled case. /// We wrap exceptions in <see cref="UnitsNetException" /> to allow you to distinguish /// Units.NET exceptions from other exceptions. /// </exception> public static MolarMass Parse(string str, [CanBeNull] IFormatProvider provider) { if (str == null) { throw new ArgumentNullException(nameof(str)); } provider = provider ?? UnitSystem.DefaultCulture; return(QuantityParser.Parse <MolarMass, MolarMassUnit>(str, provider, delegate(string value, string unit, IFormatProvider formatProvider2) { double parsedValue = double.Parse(value, formatProvider2); MolarMassUnit parsedUnit = ParseUnit(unit, formatProvider2); return From(parsedValue, parsedUnit); }, (x, y) => FromKilogramsPerMole(x.KilogramsPerMole + y.KilogramsPerMole))); }
public string ToString(MolarMassUnit unit, [CanBeNull] IFormatProvider provider, [NotNull] string format, [NotNull] params object[] args) { if (format == null) { throw new ArgumentNullException(nameof(format)); } if (args == null) { throw new ArgumentNullException(nameof(args)); } provider = provider ?? UnitSystem.DefaultCulture; double value = As(unit); object[] formatArgs = UnitFormatter.GetFormatArgs(unit, value, provider, args); return(string.Format(provider, format, formatArgs)); }
/// <summary> /// Parse a string with one or two quantities of the format "<quantity> <unit>". /// </summary> /// <param name="str">String to parse. Typically in the form: {number} {unit}</param> /// <param name="cultureName">Name of culture (ex: "en-US") to use when parsing number and unit. Defaults to <see cref="UnitSystem" />'s default culture.</param> /// <example> /// Length.Parse("5.5 m", new CultureInfo("en-US")); /// </example> /// <exception cref="ArgumentNullException">The value of 'str' cannot be null. </exception> /// <exception cref="ArgumentException"> /// Expected string to have one or two pairs of quantity and unit in the format /// "<quantity> <unit>". Eg. "5.5 m" or "1ft 2in" /// </exception> /// <exception cref="AmbiguousUnitParseException"> /// More than one unit is represented by the specified unit abbreviation. /// Example: Volume.Parse("1 cup") will throw, because it can refer to any of /// <see cref="VolumeUnit.MetricCup" />, <see cref="VolumeUnit.UsLegalCup" /> and <see cref="VolumeUnit.UsCustomaryCup" />. /// </exception> /// <exception cref="UnitsNetException"> /// If anything else goes wrong, typically due to a bug or unhandled case. /// We wrap exceptions in <see cref="UnitsNetException" /> to allow you to distinguish /// Units.NET exceptions from other exceptions. /// </exception> public static MolarMass Parse(string str, [CanBeNull] string cultureName) { if (str == null) { throw new ArgumentNullException(nameof(str)); } // Windows Runtime Component does not support CultureInfo and IFormatProvider types, so we use culture name for public methods: https://msdn.microsoft.com/en-us/library/br230301.aspx IFormatProvider provider = cultureName == null ? UnitSystem.DefaultCulture : new CultureInfo(cultureName); return(QuantityParser.Parse <MolarMass, MolarMassUnit>(str, provider, delegate(string value, string unit, IFormatProvider formatProvider2) { double parsedValue = double.Parse(value, formatProvider2); MolarMassUnit parsedUnit = ParseUnit(unit, formatProvider2); return From(parsedValue, parsedUnit); }, (x, y) => FromKilogramsPerMole(x.KilogramsPerMole + y.KilogramsPerMole))); }
// ReSharper restore VirtualMemberNeverOverriden.Global protected (double UnitsInBaseUnit, double Tolerence) GetConversionFactor(MolarMassUnit unit) { return(unit switch { MolarMassUnit.CentigramPerMole => (CentigramsPerMoleInOneKilogramPerMole, CentigramsPerMoleTolerance), MolarMassUnit.DecagramPerMole => (DecagramsPerMoleInOneKilogramPerMole, DecagramsPerMoleTolerance), MolarMassUnit.DecigramPerMole => (DecigramsPerMoleInOneKilogramPerMole, DecigramsPerMoleTolerance), MolarMassUnit.GramPerMole => (GramsPerMoleInOneKilogramPerMole, GramsPerMoleTolerance), MolarMassUnit.HectogramPerMole => (HectogramsPerMoleInOneKilogramPerMole, HectogramsPerMoleTolerance), MolarMassUnit.KilogramPerMole => (KilogramsPerMoleInOneKilogramPerMole, KilogramsPerMoleTolerance), MolarMassUnit.KilopoundPerMole => (KilopoundsPerMoleInOneKilogramPerMole, KilopoundsPerMoleTolerance), MolarMassUnit.MegapoundPerMole => (MegapoundsPerMoleInOneKilogramPerMole, MegapoundsPerMoleTolerance), MolarMassUnit.MicrogramPerMole => (MicrogramsPerMoleInOneKilogramPerMole, MicrogramsPerMoleTolerance), MolarMassUnit.MilligramPerMole => (MilligramsPerMoleInOneKilogramPerMole, MilligramsPerMoleTolerance), MolarMassUnit.NanogramPerMole => (NanogramsPerMoleInOneKilogramPerMole, NanogramsPerMoleTolerance), MolarMassUnit.PoundPerMole => (PoundsPerMoleInOneKilogramPerMole, PoundsPerMoleTolerance), _ => throw new NotSupportedException() });
/// <summary> /// Convert to the unit representation <paramref name="unit" />. /// </summary> /// <returns>Value in new unit if successful, exception otherwise.</returns> /// <exception cref="NotImplementedException">If conversion was not successful.</exception> public double As(MolarMassUnit unit) { switch (unit) { case MolarMassUnit.CentigramPerMole: return(CentigramsPerMole); case MolarMassUnit.DecagramPerMole: return(DecagramsPerMole); case MolarMassUnit.DecigramPerMole: return(DecigramsPerMole); case MolarMassUnit.GramPerMole: return(GramsPerMole); case MolarMassUnit.HectogramPerMole: return(HectogramsPerMole); case MolarMassUnit.KilogramPerMole: return(KilogramsPerMole); case MolarMassUnit.KilopoundPerMole: return(KilopoundsPerMole); case MolarMassUnit.MegapoundPerMole: return(MegapoundsPerMole); case MolarMassUnit.MicrogramPerMole: return(MicrogramsPerMole); case MolarMassUnit.MilligramPerMole: return(MilligramsPerMole); case MolarMassUnit.NanogramPerMole: return(NanogramsPerMole); case MolarMassUnit.PoundPerMole: return(PoundsPerMole); default: throw new NotImplementedException("unit: " + unit); } }
public string ToString(MolarMassUnit unit, [CanBeNull] string cultureName, [NotNull] string format, [NotNull] params object[] args) { if (format == null) { throw new ArgumentNullException(nameof(format)); } if (args == null) { throw new ArgumentNullException(nameof(args)); } // Windows Runtime Component does not support CultureInfo and IFormatProvider types, so we use culture name for public methods: https://msdn.microsoft.com/en-us/library/br230301.aspx IFormatProvider provider = cultureName == null ? UnitSystem.DefaultCulture : new CultureInfo(cultureName); double value = As(unit); object[] formatArgs = UnitFormatter.GetFormatArgs(unit, value, provider, args); return(string.Format(provider, format, formatArgs)); }
/// <summary> /// Parse a string with one or two quantities of the format "<quantity> <unit>". /// </summary> /// <param name="str">String to parse. Typically in the form: {number} {unit}</param> /// <param name="culture">Format to use when parsing number and unit. If it is null, it defaults to <see cref="NumberFormatInfo.CurrentInfo"/> for parsing the number and <see cref="CultureInfo.CurrentUICulture"/> for parsing the unit abbreviation by culture/language.</param> /// <example> /// Length.Parse("5.5 m", new CultureInfo("en-US")); /// </example> /// <exception cref="ArgumentNullException">The value of 'str' cannot be null. </exception> /// <exception cref="ArgumentException"> /// Expected string to have one or two pairs of quantity and unit in the format /// "<quantity> <unit>". Eg. "5.5 m" or "1ft 2in" /// </exception> /// <exception cref="AmbiguousUnitParseException"> /// More than one unit is represented by the specified unit abbreviation. /// Example: Volume.Parse("1 cup") will throw, because it can refer to any of /// <see cref="VolumeUnit.MetricCup" />, <see cref="VolumeUnit.UsLegalCup" /> and <see cref="VolumeUnit.UsCustomaryCup" />. /// </exception> /// <exception cref="UnitsNetException"> /// If anything else goes wrong, typically due to a bug or unhandled case. /// We wrap exceptions in <see cref="UnitsNetException" /> to allow you to distinguish /// Units.NET exceptions from other exceptions. /// </exception> public static MolarMass Parse(string str, [CanBeNull] Culture culture) { if (str == null) { throw new ArgumentNullException("str"); } // Windows Runtime Component does not support CultureInfo type, so use culture name string for public methods instead: https://msdn.microsoft.com/en-us/library/br230301.aspx #if WINDOWS_UWP IFormatProvider formatProvider = culture == null ? null : new CultureInfo(culture); #else IFormatProvider formatProvider = culture; #endif return(QuantityParser.Parse <MolarMass, MolarMassUnit>(str, formatProvider, delegate(string value, string unit, IFormatProvider formatProvider2) { double parsedValue = double.Parse(value, formatProvider2); MolarMassUnit parsedUnit = ParseUnit(unit, formatProvider2); return From(parsedValue, parsedUnit); }, (x, y) => FromKilogramsPerMole(x.KilogramsPerMole + y.KilogramsPerMole))); }
private double AsBaseNumericType(MolarMassUnit unit) { if (Unit == unit) { return(_value); } var baseUnitValue = AsBaseUnit(); switch (unit) { case MolarMassUnit.CentigramPerMole: return((baseUnitValue * 1e3) / 1e-2d); case MolarMassUnit.DecagramPerMole: return((baseUnitValue * 1e3) / 1e1d); case MolarMassUnit.DecigramPerMole: return((baseUnitValue * 1e3) / 1e-1d); case MolarMassUnit.GramPerMole: return(baseUnitValue * 1e3); case MolarMassUnit.HectogramPerMole: return((baseUnitValue * 1e3) / 1e2d); case MolarMassUnit.KilogramPerMole: return((baseUnitValue * 1e3) / 1e3d); case MolarMassUnit.KilopoundPerMole: return((baseUnitValue / 0.45359237) / 1e3d); case MolarMassUnit.MegapoundPerMole: return((baseUnitValue / 0.45359237) / 1e6d); case MolarMassUnit.MicrogramPerMole: return((baseUnitValue * 1e3) / 1e-6d); case MolarMassUnit.MilligramPerMole: return((baseUnitValue * 1e3) / 1e-3d); case MolarMassUnit.NanogramPerMole: return((baseUnitValue * 1e3) / 1e-9d); case MolarMassUnit.PoundPerMole: return(baseUnitValue / 0.45359237); default: throw new NotImplementedException($"Can not convert {Unit} to {unit}."); } }
public string ToString(MolarMassUnit unit, [CanBeNull] Culture culture, [NotNull] string format, [NotNull] params object[] args) { if (format == null) { throw new ArgumentNullException(nameof(format)); } if (args == null) { throw new ArgumentNullException(nameof(args)); } // Windows Runtime Component does not support CultureInfo type, so use culture name string for public methods instead: https://msdn.microsoft.com/en-us/library/br230301.aspx #if WINDOWS_UWP IFormatProvider formatProvider = culture == null ? null : new CultureInfo(culture); #else IFormatProvider formatProvider = culture; #endif double value = As(unit); object[] formatArgs = UnitFormatter.GetFormatArgs(unit, value, formatProvider, args); return(string.Format(formatProvider, format, formatArgs)); }
public static string GetAbbreviation( MolarMassUnit unit, #if WINDOWS_UWP [CanBeNull] string cultureName)
public static string GetAbbreviation(MolarMassUnit unit) { return(GetAbbreviation(unit, null)); }
public static MolarMass From(QuantityValue value, MolarMassUnit fromUnit) #endif { return(new MolarMass((double)value, fromUnit)); }
public static MolarMass From(double value, MolarMassUnit fromUnit)