lob 0.6.5
 
Loading...
Searching...
No Matches
lob.hpp
Go to the documentation of this file.
1// Copyright (c) 2025 Joel Benway
2// SPDX-License-Identifier: GPL-3.0-or-later
3// Please see end of file for extended copyright information
4
5#pragma once
6
7#include <array>
8#include <cstddef>
9#include <cstdint>
10#include <limits>
11#include <type_traits>
12
13#include "lob/lob_export.hpp"
14
15namespace lob {
16
21LOB_EXPORT const char* Version();
22
26enum class LOB_EXPORT DragFunctionT : uint8_t {
27 kG1 = 1U,
28 kG2 = 2U,
29 kG5 = 5U,
30 kG6 = 6U,
31 kG7 = 7U,
32 kG8 = 8U
33};
34
38enum class LOB_EXPORT AtmosphereReferenceT : uint8_t {
39 kArmyStandardMetro,
41};
42
48enum class LOB_EXPORT ClockAngleT : uint8_t {
49 kI = 1U,
61}; // enum class ClockAngleT
62
63enum class LOB_EXPORT ErrorT : uint8_t {
64 kNone,
87}; // enum class ErrorT
88
90template <typename T = double>
91constexpr T NaN() {
92 static_assert(std::is_floating_point<T>::value,
93 "NaN() only supports floating-point types");
94 return std::numeric_limits<T>::quiet_NaN();
95}
96
102struct LOB_EXPORT Input {
103 static constexpr uint8_t kTableSize{85};
104 std::array<uint16_t, kTableSize> drags{};
106 double speed_of_sound{NaN()};
107 uint16_t velocity{0};
108 double mass{NaN()};
109 double optic_height{NaN()};
110 struct Gravity {
111 double x{NaN()};
112 double y{NaN()};
113 } gravity;
114 struct Wind {
115 double x{NaN()};
116 double z{NaN()};
117 } wind;
118 struct Coriolis {
119 double cos_l_sin_a{NaN()};
120 double sin_l{NaN()};
121 double cos_l_cos_a{NaN()};
122 } corilolis;
123 double zero_angle{NaN()};
127 uint16_t minimum_speed{0};
128 double max_time{NaN()};
129 uint16_t step_size{0};
130 ErrorT error{ErrorT::kNotFormed};
131}; // struct Input
132
133class Impl;
134
139class LOB_EXPORT Builder {
140 public:
143 Builder(const Builder& other);
144 Builder(Builder&& other) noexcept;
146 const Builder& rhs);
148 Builder&& rhs) noexcept;
149
156
163
170
176 Builder& DiameterInch(double value);
177
184
190 Builder& BaseDiameterInch(double value);
191
197 Builder& LengthInch(double value);
198
204 Builder& NoseLengthInch(double value);
205
211 Builder& TailLengthInch(double value);
212
218 Builder& OgiveRtR(double value);
219
229 Builder& MachVsDragTable(const float* pmachs, const float* pdrags,
230 size_t size);
240 template <size_t N>
241 Builder& MachVsDragTable(const std::array<float, N>& machs,
242 const std::array<float, N>& drags) {
243 return MachVsDragTable(machs.data(), drags.data(), N);
244 }
245
251 Builder& MassGrains(double value);
252
258 Builder& InitialVelocityFps(uint16_t value);
265
273
282 Builder& ZeroAngleMOA(double value);
283
289 Builder& ZeroDistanceYds(double value);
290
299
306
312 Builder& AirPressureInHg(double value);
313
324
330 Builder& TemperatureDegF(double value);
331
342
349
357
364 Builder& WindHeadingDeg(double value);
365
371 Builder& WindSpeedFps(double value);
372
378 Builder& WindSpeedMph(double value);
379
386 Builder& AzimuthDeg(double value);
387
394 Builder& LatitudeDeg(double value);
395
401 Builder& RangeAngleDeg(double value);
402
409 Builder& MinimumSpeed(uint16_t value);
410
417 Builder& MinimumEnergy(uint16_t value);
418
425 Builder& MaximumTime(double value);
426
432 Builder& StepSize(uint16_t value);
433
438 Builder& Reset() noexcept;
439
444 bool IsValid() const;
445
451
452 private:
453 static constexpr size_t kBufferSize{536};
454 union AlignmentT {
455 double foo;
456 size_t bar;
457 };
458 alignas(AlignmentT) std::array<uint8_t, kBufferSize> buffer_{};
459 Impl* pimpl_{nullptr};
460}; // class Builder
461
465struct LOB_EXPORT Output {
466 uint32_t range{0};
467 uint16_t velocity{0};
468 uint32_t energy{0};
469 double elevation{0.0};
470 double deflection{0.0};
471 double time_of_flight{0.0};
472}; // struct Output
473
482LOB_EXPORT size_t Solve(const Input& in, const uint32_t* pranges, Output* pouts,
483 size_t size);
484
493template <size_t N>
494size_t Solve(const Input& in, const std::array<uint32_t, N>& pranges,
495 std::array<Output, N>& pouts) {
496 return Solve(in, pranges.data(), pouts.data(), N);
497}
498
504LOB_EXPORT double MoaToMil(double value);
505
511LOB_EXPORT double MoaToDeg(double value);
512
518LOB_EXPORT double MoaToIphy(double value);
519
527LOB_EXPORT double MoaToInch(double value, double range_ft);
528
534LOB_EXPORT double MilToMoa(double value);
535
541LOB_EXPORT double MilToDeg(double value);
542
548LOB_EXPORT double MilToIphy(double value);
549
557LOB_EXPORT double MilToInch(double value, double range_ft);
558
564LOB_EXPORT double DegToMoa(double value);
565
571LOB_EXPORT double DegToMil(double value);
572
579LOB_EXPORT double InchToMoa(double value, double range_ft);
580
587LOB_EXPORT double InchToMil(double value, double range_ft);
588
595LOB_EXPORT double InchToDeg(double value, double range_ft);
596
602LOB_EXPORT double JToFtLbs(double value);
603
609LOB_EXPORT double FtLbsToJ(double value);
610
616LOB_EXPORT double MtoYd(double value);
617
623LOB_EXPORT double YdToFt(double value);
624
630LOB_EXPORT double MToFt(double value);
631
637LOB_EXPORT double FtToIn(double value);
638
644LOB_EXPORT double MmToIn(double value);
645
651LOB_EXPORT double CmToIn(double value);
652
658LOB_EXPORT double YdToM(double value);
659
665LOB_EXPORT double FtToM(double value);
666
672LOB_EXPORT double FtToYd(double value);
673
679LOB_EXPORT double InToMm(double value);
680
686LOB_EXPORT double InToCm(double value);
687
693LOB_EXPORT double InToFt(double value);
694
700LOB_EXPORT double PaToInHg(double value);
701
707LOB_EXPORT double MbarToInHg(double value);
708
714LOB_EXPORT double PsiToInHg(double value);
715
721LOB_EXPORT double LbsToGrain(double value);
722
728LOB_EXPORT double GToGrain(double value);
729
735LOB_EXPORT double KgToGrain(double value);
736
742LOB_EXPORT double KgSqMToPmsi(double value);
743
749LOB_EXPORT double FpsToMps(double value);
750
756LOB_EXPORT double MpsToFps(double value);
757
763LOB_EXPORT double KphToMph(double value);
764
770LOB_EXPORT double KnToMph(double value);
771
777LOB_EXPORT double MsToS(double value);
778
784LOB_EXPORT double UsToS(double value);
785
791LOB_EXPORT double SToMs(double value);
792
798LOB_EXPORT double SToUs(double value);
799
805LOB_EXPORT double DegCToDegF(double value);
806
807} // namespace lob
808
809// This file is part of lob.
810//
811// lob is free software: you can redistribute it and/or modify it under the
812// terms of the GNU General Public License as published by the Free Software
813// Foundation, either version 3 of the License, or (at your option) any later
814// version.
815//
816// lob is distributed in the hope that it will be useful, but WITHOUT ANY
817// WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
818// A PARTICULAR PURPOSE. See the GNU General Public License for more details.
819//
820// You should have received a copy of the GNU General Public License along with
821// lob. If not, see <https://www.gnu.org/licenses/>.
Builder & WindHeadingDeg(double value)
Sets the wind heading in degrees.
Builder & LengthInch(double value)
Sets the projectile length in inches.
Builder & TemperatureDegF(double value)
Sets the temperature in degrees Fahrenheit.
Builder & ZeroAngleMOA(double value)
Sets the angle between the sight and launch angle used to achieve zero.
Builder & operator=(const Builder &rhs)
Move constructor.
Builder & MaximumTime(double value)
Sets the maximum time of flight for the solver.
Input Build()
Builds the Input object with the configured parameters.
Builder & MassGrains(double value)
Sets the projectile mass in grains.
Builder & AzimuthDeg(double value)
Sets the azimuth (bearing) of the target in degrees.
Builder & TailLengthInch(double value)
Sets the projectile tail length in inches.
Builder & operator=(Builder &&rhs) noexcept
Copy assignment constructor.
bool IsValid() const
Checks if the current builder state is well-formed.
Builder & InitialVelocityFps(uint16_t value)
Sets the initial velocity of the projectile in feet per second.
Builder & AltitudeOfFiringSiteFt(double value)
Sets the altitude of the firing site in feet.
Builder & MeplatDiameterInch(double value)
Sets the projectile meplat diameter in inches.
Builder & MinimumEnergy(uint16_t value)
Sets the minimum energy threshold for the solver.
Builder & BallisticCoefficientPsi(double value)
Move assignment constructor.
Builder & AirPressureInHg(double value)
Sets the air pressure in inches of mercury (inHg).
~Builder()
Default constructor.
Builder & DiameterInch(double value)
Sets the projectile diameter (caliber) in inches.
Builder & WindHeading(ClockAngleT value)
Sets the wind heading using a clock angle.
Builder & MachVsDragTable(const std::array< float, N > &machs, const std::array< float, N > &drags)
Loads a custom Mach vs Drag table for the projectile.
Definition lob.hpp:241
Builder & LatitudeDeg(double value)
Sets the latitude of the firing location in degrees.
Builder & OpticHeightInches(double value)
Sets the height of the optic above the bore in inches.
Builder & BCAtmosphere(AtmosphereReferenceT type)
Sets the atmosphere reference associated with ballistic coefficient.
Builder & Reset() noexcept
Resets the builder state by creating a fresh Impl object.
Builder & ZeroDistanceYds(double value)
Sets the zero distance in yards.
Builder & MinimumSpeed(uint16_t value)
Sets the minimum speed threshold for the solver.
Builder & RangeAngleDeg(double value)
Sets the range angle (inclination) to the target in degrees.
Builder(const Builder &other)
Default destructor.
Builder & WindSpeedMph(double value)
Sets the wind speed in miles per hour.
Builder & BCDragFunction(DragFunctionT type)
Sets the drag function associated with ballistic coefficient.
Builder & ZeroImpactHeightInches(double value)
Sets the zero impact height in inches.
Builder(Builder &&other) noexcept
Copy constructor.
Builder & NoseLengthInch(double value)
Sets the projectile nose length in inches.
Builder & AltitudeOfBarometerFt(double value)
Sets the altitude of the location where air pressure was taken in feet.
Builder & OgiveRtR(double value)
Sets the Rt/R ratio of the projectile ogive.
Builder & TwistInchesPerTurn(double value)
Sets the twist rate of the barrel in inches per turn.
Builder & WindSpeedFps(double value)
Sets the wind speed in feet per second.
Builder & StepSize(uint16_t value)
Sets the step size for the numerical solver.
Builder & MachVsDragTable(const float *pmachs, const float *pdrags, size_t size)
Loads a custom Mach vs Drag table for the projectile.
Builder & BaseDiameterInch(double value)
Sets the projectile base diameter in inches.
Builder & RelativeHumidityPercent(double value)
Sets the relative humidity at the firing site in percent.
Builder & AltitudeOfThermometerFt(double value)
Sets the altitude of the location where temperature was taken in feet.
Definition lob.hpp:15
LOB_EXPORT double PsiToInHg(double value)
Converts pounds per square inch (PSI) to inches of mercury.
enum LOB_EXPORT kLength
Definition lob.hpp:74
LOB_EXPORT double SToMs(double value)
Converts seconds to milliseconds.
enum LOB_EXPORT kBaseDiameter
Definition lob.hpp:69
constexpr T NaN()
Not-a-Number for floating-point values.
Definition lob.hpp:91
enum LOB_EXPORT kG7
G6 drag function.
Definition lob.hpp:31
enum LOB_EXPORT kMeplatDiameter
Definition lob.hpp:78
enum LOB_EXPORT DragFunctionT
Enumerates the supported drag functions.
Definition lob.hpp:26
LOB_EXPORT double JToFtLbs(double value)
Converts joules to foot-pounds.
LOB_EXPORT double SToUs(double value)
Converts seconds to microseconds.
enum LOB_EXPORT ErrorT
Definition lob.hpp:63
enum LOB_EXPORT kVI
five o'clock
Definition lob.hpp:54
enum LOB_EXPORT kWindHeading
Definition lob.hpp:83
enum LOB_EXPORT kNotFormed
Definition lob.hpp:87
enum LOB_EXPORT kV
four o'clock
Definition lob.hpp:53
LOB_EXPORT double MmToIn(double value)
Converts millimeters to inches.
enum LOB_EXPORT kBallisticCoefficient
Definition lob.hpp:68
enum LOB_EXPORT kX
nine o'clock
Definition lob.hpp:58
LOB_EXPORT double KphToMph(double value)
Converts kilometers per hour to miles per hour.
enum LOB_EXPORT kTailLength
Definition lob.hpp:82
LOB_EXPORT double InchToMil(double value, double range_ft)
Inches of projection at a given range to milliradians (MIL)
enum LOB_EXPORT kVII
six o'clock
Definition lob.hpp:55
LOB_EXPORT double MtoYd(double value)
Converts meters to yards.
enum LOB_EXPORT kAirPressure
Definition lob.hpp:65
enum LOB_EXPORT AtmosphereReferenceT
Enumerates the supported atmosphere reference types.
Definition lob.hpp:38
enum LOB_EXPORT kII
one o'clock
Definition lob.hpp:50
enum LOB_EXPORT kMaximumTime
Definition lob.hpp:77
LOB_EXPORT double YdToM(double value)
Converts yards to meters.
LOB_EXPORT double InToFt(double value)
Converts inches to feet.
LOB_EXPORT double DegToMoa(double value)
Converts degrees to minutes of angle (MOA).
LOB_EXPORT double UsToS(double value)
Converts microseconds to seconds.
LOB_EXPORT double MoaToDeg(double value)
Converts minutes of angle (MOA) to degrees.
enum LOB_EXPORT kG2
G1 drag function.
Definition lob.hpp:28
enum LOB_EXPORT kG8
G7 drag function.
Definition lob.hpp:32
enum LOB_EXPORT kMachDragTable
Definition lob.hpp:75
LOB_EXPORT double MoaToInch(double value, double range_ft)
Converts minutes of angle (MOA) to projected inches at a given range in feet.
enum LOB_EXPORT kVIII
seven o'clock
Definition lob.hpp:56
LOB_EXPORT double PaToInHg(double value)
Converts pascals to inches of mercury.
LOB_EXPORT double DegCToDegF(double value)
Converts degrees celsius to degrees fahrenheit.
LOB_EXPORT const char * Version()
Gets the library version in major.minor.patch format.
enum LOB_EXPORT kIcao
Army Standard Metro.
Definition lob.hpp:41
enum LOB_EXPORT kInitialVelocity
Definition lob.hpp:72
LOB_EXPORT double CmToIn(double value)
Converts centimeters to inches.
enum LOB_EXPORT kZeroDistance
Definition lob.hpp:85
LOB_EXPORT double KnToMph(double value)
Converts Knots to miles per hour.
enum LOB_EXPORT kLatitude
Definition lob.hpp:73
LOB_EXPORT size_t Solve(const Input &in, const uint32_t *pranges, Output *pouts, size_t size)
Solves the exterior ballistics problem for a given set of ranges.
enum LOB_EXPORT kG5
G2 drag function.
Definition lob.hpp:29
enum LOB_EXPORT kIV
three o'clock
Definition lob.hpp:52
enum LOB_EXPORT kRangeAngle
Definition lob.hpp:81
LOB_EXPORT double InchToMoa(double value, double range_ft)
Inches of projection at a given range to minutes of angle (MOA)
LOB_EXPORT double MToFt(double value)
Converts meters to feet.
LOB_EXPORT double InToMm(double value)
Converts inches to millimeters.
LOB_EXPORT double InchToDeg(double value, double range_ft)
Inches of projection at a given range to degrees.
LOB_EXPORT double GToGrain(double value)
Converts grams to grains.
enum LOB_EXPORT kMass
Definition lob.hpp:76
enum LOB_EXPORT kG6
G5 drag function.
Definition lob.hpp:30
LOB_EXPORT double KgSqMToPmsi(double value)
Converts kilograms per square meter to pounds mass per square inch.
enum LOB_EXPORT kIX
eight o'clock
Definition lob.hpp:57
LOB_EXPORT double MoaToIphy(double value)
Converts minutes of angle (MOA) to inches per hundred yards (IPHY).
LOB_EXPORT double MbarToInHg(double value)
Converts millibars to inches of mercury.
LOB_EXPORT double MsToS(double value)
Converts milliseconds to seconds.
LOB_EXPORT double MpsToFps(double value)
Converts meters per second to feet per second.
LOB_EXPORT double FtLbsToJ(double value)
Converts foot-pounds to joules.
enum LOB_EXPORT kNoseLength
Definition lob.hpp:79
LOB_EXPORT double MilToMoa(double value)
Converts milliradians (MIL) to minutes of angle (MOA).
LOB_EXPORT double DegToMil(double value)
Converts degrees to milliradians (MIL).
LOB_EXPORT double LbsToGrain(double value)
Converts pounds to grains.
LOB_EXPORT double FtToIn(double value)
Converts feet to inches.
enum LOB_EXPORT kAzimuth
Definition lob.hpp:67
LOB_EXPORT double FtToM(double value)
Converts feet to meters.
enum LOB_EXPORT kIII
two o'clock
Definition lob.hpp:51
enum LOB_EXPORT kZeroAngle
Definition lob.hpp:84
enum LOB_EXPORT kOgiveRtR
Definition lob.hpp:80
LOB_EXPORT double YdToFt(double value)
Converts yards to feet.
enum LOB_EXPORT kAltitude
Definition lob.hpp:66
LOB_EXPORT double KgToGrain(double value)
Converts kilograms to grains.
LOB_EXPORT double MilToInch(double value, double range_ft)
Converts milliradians (MIL) to projected inches at a given range in feet.
LOB_EXPORT double InToCm(double value)
Converts inches to centimeters.
enum LOB_EXPORT kHumidity
Definition lob.hpp:71
enum LOB_EXPORT ClockAngleT
Enumerates clock angle positions.
Definition lob.hpp:48
LOB_EXPORT double MilToIphy(double value)
Converts milliradians (MIL) to inches per hundred yards (IPHY).
LOB_EXPORT double FtToYd(double value)
Converts feet to yards.
LOB_EXPORT double MoaToMil(double value)
Converts minutes of angle (MOA) to milliradians (MIL).
enum LOB_EXPORT kXI
ten o'clock
Definition lob.hpp:59
LOB_EXPORT double MilToDeg(double value)
Converts milliradians (MIL) to degrees.
enum LOB_EXPORT kDiameter
Definition lob.hpp:70
LOB_EXPORT double FpsToMps(double value)
Converts feet per second to meters per second.
enum LOB_EXPORT kXII
eleven o'clock
Definition lob.hpp:61
Definition lob.hpp:118
double cos_l_sin_a
Coriolis effect parameters.
Definition lob.hpp:119
double sin_l
2Ωcos(latitude)sin(azimuth)
Definition lob.hpp:120
double cos_l_cos_a
2Ωsin(latitude)
Definition lob.hpp:121
Height of the optic above the bore.
Definition lob.hpp:110
double x
Gravity vector.
Definition lob.hpp:111
double y
Acceleration ft/s/s in the x-direction.
Definition lob.hpp:112
Definition lob.hpp:114
double x
Wind vector.
Definition lob.hpp:115
double z
Wind speed in fps in the x-direction.
Definition lob.hpp:116
Structure of input parameters consumed by the solver.
Definition lob.hpp:102
std::array< uint16_t, kTableSize > drags
The size of drag table.
Definition lob.hpp:104
double max_time
Minimum speed for solver.
Definition lob.hpp:128
double spindrift_factor
Aerodynamic jump effect in Moa.
Definition lob.hpp:126
double optic_height
Mass of the projectile in pounds.
Definition lob.hpp:109
double mass
Initial velocity of projectile in Fps.
Definition lob.hpp:108
double zero_angle
Definition lob.hpp:123
double aerodynamic_jump
Miller stability factor.
Definition lob.hpp:125
uint16_t velocity
The local speed of sound in Fps.
Definition lob.hpp:107
uint16_t step_size
Max time of flight for solver.
Definition lob.hpp:129
uint16_t minimum_speed
Spin drift factor.
Definition lob.hpp:127
double table_coefficient
The drag table.
Definition lob.hpp:105
double speed_of_sound
Used to scale the drag table.
Definition lob.hpp:106
double stability_factor
Angle between sight and trajectory.
Definition lob.hpp:124
ErrorT error
Step size for solver.
Definition lob.hpp:130
static constexpr uint8_t kTableSize
Definition lob.hpp:103
Structure holding the output results of the ballistic calculation.
Definition lob.hpp:465
double elevation
Calculated energy in foot-pounds.
Definition lob.hpp:469
uint32_t range
Definition lob.hpp:466
double time_of_flight
Calculated windage deflection in inches.
Definition lob.hpp:471
uint16_t velocity
Associated range in yards.
Definition lob.hpp:467
uint32_t energy
Calculated velocity in feet per second.
Definition lob.hpp:468
double deflection
Calculated elevation change in inches.
Definition lob.hpp:470