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
230 Builder& MachVsDragTable(const float* pmachs, const float* pdrags,
231 size_t size);
241 template <size_t N>
242 Builder& MachVsDragTable(const std::array<float, N>& machs,
243 const std::array<float, N>& drags) {
244 return MachVsDragTable(machs.data(), drags.data(), N);
245 }
246
252 Builder& MassGrains(double value);
253
259 Builder& InitialVelocityFps(uint16_t value);
266
274
283 Builder& ZeroAngleMOA(double value);
284
290 Builder& ZeroDistanceYds(double value);
291
300
307
313 Builder& AirPressureInHg(double value);
314
325
331 Builder& TemperatureDegF(double value);
332
343
350
358
365 Builder& WindHeadingDeg(double value);
366
372 Builder& WindSpeedFps(double value);
373
379 Builder& WindSpeedMph(double value);
380
387 Builder& AzimuthDeg(double value);
388
395 Builder& LatitudeDeg(double value);
396
402 Builder& RangeAngleDeg(double value);
403
410 Builder& MinimumSpeed(uint16_t value);
411
418 Builder& MinimumEnergy(uint16_t value);
419
426 Builder& MaximumTime(double value);
427
433 Builder& StepSize(uint16_t value);
434
439 Builder& Reset() noexcept;
440
446
447 private:
448 static constexpr size_t kBufferSize{536};
449 union AlignmentT {
450 double foo;
451 size_t bar;
452 };
453 alignas(AlignmentT) std::array<uint8_t, kBufferSize> buffer_{};
454 Impl* pimpl_{nullptr};
455}; // class Builder
456
460struct LOB_EXPORT Output {
461 uint32_t range{0};
462 uint16_t velocity{0};
463 uint32_t energy{0};
464 double elevation{0.0};
465 double deflection{0.0};
466 double time_of_flight{0.0};
467}; // struct Output
468
477LOB_EXPORT size_t Solve(const Input& in, const uint32_t* pranges, Output* pouts,
478 size_t size);
479
488template <size_t N>
489size_t Solve(const Input& in, const std::array<uint32_t, N>& pranges,
490 std::array<Output, N>& pouts) {
491 return Solve(in, pranges.data(), pouts.data(), N);
492}
493
499LOB_EXPORT double MoaToMil(double value);
500
506LOB_EXPORT double MoaToDeg(double value);
507
513LOB_EXPORT double MoaToIphy(double value);
514
522LOB_EXPORT double MoaToInch(double value, double range_ft);
523
529LOB_EXPORT double MilToMoa(double value);
530
536LOB_EXPORT double MilToDeg(double value);
537
543LOB_EXPORT double MilToIphy(double value);
544
552LOB_EXPORT double MilToInch(double value, double range_ft);
553
559LOB_EXPORT double DegToMoa(double value);
560
566LOB_EXPORT double DegToMil(double value);
567
574LOB_EXPORT double InchToMoa(double value, double range_ft);
575
582LOB_EXPORT double InchToMil(double value, double range_ft);
583
590LOB_EXPORT double InchToDeg(double value, double range_ft);
591
597LOB_EXPORT double JToFtLbs(double value);
598
604LOB_EXPORT double FtLbsToJ(double value);
605
611LOB_EXPORT double MtoYd(double value);
612
618LOB_EXPORT double YdToFt(double value);
619
625LOB_EXPORT double MToFt(double value);
626
632LOB_EXPORT double FtToIn(double value);
633
639LOB_EXPORT double MmToIn(double value);
640
646LOB_EXPORT double CmToIn(double value);
647
653LOB_EXPORT double YdToM(double value);
654
660LOB_EXPORT double FtToM(double value);
661
667LOB_EXPORT double FtToYd(double value);
668
674LOB_EXPORT double InToMm(double value);
675
681LOB_EXPORT double InToCm(double value);
682
688LOB_EXPORT double InToFt(double value);
689
695LOB_EXPORT double PaToInHg(double value);
696
702LOB_EXPORT double MbarToInHg(double value);
703
709LOB_EXPORT double PsiToInHg(double value);
710
716LOB_EXPORT double LbsToGrain(double value);
717
723LOB_EXPORT double GToGrain(double value);
724
730LOB_EXPORT double KgToGrain(double value);
731
737LOB_EXPORT double KgSqMToPmsi(double value);
738
744LOB_EXPORT double FpsToMps(double value);
745
751LOB_EXPORT double MpsToFps(double value);
752
758LOB_EXPORT double KphToMph(double value);
759
765LOB_EXPORT double KnToMph(double value);
766
772LOB_EXPORT double MsToS(double value);
773
779LOB_EXPORT double UsToS(double value);
780
786LOB_EXPORT double SToMs(double value);
787
793LOB_EXPORT double SToUs(double value);
794
800LOB_EXPORT double DegCToDegF(double value);
801
802} // namespace lob
803
804// This file is part of lob.
805//
806// lob is free software: you can redistribute it and/or modify it under the
807// terms of the GNU General Public License as published by the Free Software
808// Foundation, either version 3 of the License, or (at your option) any later
809// version.
810//
811// lob is distributed in the hope that it will be useful, but WITHOUT ANY
812// WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
813// A PARTICULAR PURPOSE. See the GNU General Public License for more details.
814//
815// You should have received a copy of the GNU General Public License along with
816// 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.
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:242
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:460
double elevation
Calculated energy in foot-pounds.
Definition lob.hpp:464
uint32_t range
Definition lob.hpp:461
double time_of_flight
Calculated windage deflection in inches.
Definition lob.hpp:466
uint16_t velocity
Associated range in yards.
Definition lob.hpp:462
uint32_t energy
Calculated velocity in feet per second.
Definition lob.hpp:463
double deflection
Calculated elevation change in inches.
Definition lob.hpp:465