2017-04-27 20:24:53 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
2013-05-04 17:24:23 -03:00
|
|
|
#ifndef PROFILE_H
|
|
|
|
#define PROFILE_H
|
|
|
|
|
2016-02-01 18:00:49 -08:00
|
|
|
#include "dive.h"
|
2024-01-21 00:35:44 +01:00
|
|
|
#include "sample.h"
|
2016-02-01 18:00:49 -08:00
|
|
|
|
2013-05-04 17:24:23 -03:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-02-27 20:09:57 -08:00
|
|
|
typedef enum {
|
|
|
|
STABLE,
|
|
|
|
SLOW,
|
|
|
|
MODERATE,
|
|
|
|
FAST,
|
|
|
|
CRAZY
|
|
|
|
} velocity_t;
|
2013-05-04 19:36:40 -03:00
|
|
|
|
2019-07-05 23:29:34 +02:00
|
|
|
enum plot_pressure {
|
|
|
|
SENSOR_PR = 0,
|
|
|
|
INTERPOLATED_PR = 1,
|
|
|
|
NUM_PLOT_PRESSURES = 2
|
|
|
|
};
|
|
|
|
|
2014-01-18 16:21:13 -08:00
|
|
|
struct membuffer;
|
2019-08-05 20:43:06 +02:00
|
|
|
struct deco_state;
|
2013-05-04 17:24:23 -03:00
|
|
|
struct divecomputer;
|
2019-08-05 20:43:06 +02:00
|
|
|
|
2019-07-06 17:18:43 +02:00
|
|
|
/*
|
|
|
|
* sensor data for a given cylinder
|
|
|
|
*/
|
|
|
|
struct plot_pressure_data {
|
|
|
|
int data[NUM_PLOT_PRESSURES];
|
|
|
|
};
|
|
|
|
|
2013-05-04 19:36:40 -03:00
|
|
|
struct plot_data {
|
2014-02-27 20:09:57 -08:00
|
|
|
unsigned int in_deco : 1;
|
2016-03-10 07:37:18 -08:00
|
|
|
int sec;
|
2013-05-04 19:36:40 -03:00
|
|
|
int temperature;
|
|
|
|
/* Depth info */
|
|
|
|
int depth;
|
|
|
|
int ceiling;
|
2013-05-30 20:56:00 +02:00
|
|
|
int ceilings[16];
|
2014-09-15 14:09:00 +02:00
|
|
|
int percentages[16];
|
2013-05-04 19:36:40 -03:00
|
|
|
int ndl;
|
2014-07-09 22:13:36 +02:00
|
|
|
int tts;
|
Add support for RBT reported sample value
RBT (Remaining Bottom Time) is a value calculated on the fly by some air
integrated divecomputers, for example Uwatec devices. This value is an
estimation based in some heuristic around time function pressure
gradients. This way, RBT would be the time a diver can spend at actual
depth without running out of gas (taking account of ascent, deco, if
required, and rock bottom gas reserve, if set).
Older Uwatec devices just made the calculus and only stored alarm events
if this time value reached zero, but modern devices store the value each
sample, in minutes.
It seems that Suunto Eon Steel is storing RBT values too, in seconds.
Libdivecomputer has supported RBT for a while, but Subsurface just
printed it to stdout and dropped it.
This adds support for RBT value on subsurface sample structure and shows
it in the profile's info box, right under TTS(calc), if selected, where
these two values can be easily compared by humans.
Signed-off-by: Salvador Cuñat <salvador.cunat@gmail.com>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
2015-07-22 17:02:33 +02:00
|
|
|
int rbt;
|
2013-05-04 19:36:40 -03:00
|
|
|
int stoptime;
|
|
|
|
int stopdepth;
|
|
|
|
int cns;
|
|
|
|
int smoothed;
|
2013-10-14 23:48:43 +02:00
|
|
|
int sac;
|
2014-12-12 14:30:13 +01:00
|
|
|
int running_sum;
|
2014-09-15 14:55:20 +02:00
|
|
|
struct gas_pressures pressures;
|
2014-11-18 10:30:24 +01:00
|
|
|
pressure_t o2pressure; // for rebreathers, this is consensus measured po2, or setpoint otherwise. 0 for OC.
|
2024-01-21 00:35:44 +01:00
|
|
|
pressure_t o2sensor[MAX_O2_SENSORS]; //for rebreathers with several sensors
|
2015-01-05 09:20:26 +02:00
|
|
|
pressure_t o2setpoint;
|
2018-03-14 17:13:37 +02:00
|
|
|
pressure_t scr_OC_pO2;
|
2021-12-03 14:59:36 +01:00
|
|
|
int mod, ead, end, eadd;
|
2013-05-04 19:36:40 -03:00
|
|
|
velocity_t velocity;
|
2013-09-25 02:07:07 +02:00
|
|
|
int speed;
|
2013-11-13 19:20:09 +01:00
|
|
|
/* values calculated by us */
|
2014-02-27 20:09:57 -08:00
|
|
|
unsigned int in_deco_calc : 1;
|
2013-11-13 19:20:09 +01:00
|
|
|
int ndl_calc;
|
|
|
|
int tts_calc;
|
|
|
|
int stoptime_calc;
|
|
|
|
int stopdepth_calc;
|
2014-01-01 10:35:16 -02:00
|
|
|
int pressure_time;
|
2014-01-17 14:00:28 -08:00
|
|
|
int heartbeat;
|
|
|
|
int bearing;
|
2014-09-15 14:09:00 +02:00
|
|
|
double ambpressure;
|
|
|
|
double gfline;
|
2019-01-23 16:46:45 +01:00
|
|
|
double surface_gf;
|
2019-11-28 10:37:44 +01:00
|
|
|
double current_gf;
|
2017-05-12 15:36:24 +02:00
|
|
|
double density;
|
2018-04-10 21:20:38 +02:00
|
|
|
bool icd_warning;
|
2013-05-04 19:36:40 -03:00
|
|
|
};
|
2014-08-24 20:48:22 +02:00
|
|
|
|
2022-03-12 11:11:04 +01:00
|
|
|
/* Plot info with smoothing, velocity indication
|
|
|
|
* and one-, two- and three-minute minimums and maximums */
|
|
|
|
struct plot_info {
|
|
|
|
int nr;
|
|
|
|
int nr_cylinders;
|
|
|
|
int maxtime;
|
|
|
|
int meandepth, maxdepth;
|
|
|
|
int minpressure, maxpressure;
|
|
|
|
int minhr, maxhr;
|
|
|
|
int mintemp, maxtemp;
|
|
|
|
enum {AIR, NITROX, TRIMIX, FREEDIVING} dive_type;
|
|
|
|
double endtempcoord;
|
|
|
|
double maxpp;
|
|
|
|
bool waypoint_above_ceiling;
|
|
|
|
struct plot_data *entry;
|
|
|
|
struct plot_pressure_data *pressures; /* cylinders.nr blocks of nr entries. */
|
|
|
|
};
|
|
|
|
|
|
|
|
#define AMB_PERCENTAGE 50.0
|
|
|
|
|
2019-08-25 12:56:41 +02:00
|
|
|
extern void init_plot_info(struct plot_info *pi);
|
2021-01-08 23:55:20 +01:00
|
|
|
/* when planner_dc is non-null, this is called in planner mode. */
|
2021-12-10 17:44:37 +01:00
|
|
|
extern void create_plot_info_new(const struct dive *dive, const struct divecomputer *dc, struct plot_info *pi, const struct deco_state *planner_ds);
|
2019-07-05 23:35:57 +02:00
|
|
|
extern void free_plot_info_data(struct plot_info *pi);
|
2013-05-04 17:24:23 -03:00
|
|
|
|
2013-05-04 19:20:49 -03:00
|
|
|
/*
|
|
|
|
* When showing dive profiles, we scale things to the
|
|
|
|
* current dive. However, we don't scale past less than
|
|
|
|
* 30 minutes or 90 ft, just so that small dives show
|
|
|
|
* up as such unless zoom is enabled.
|
|
|
|
* We also need to add 180 seconds at the end so the min/max
|
|
|
|
* plots correctly
|
|
|
|
*/
|
2020-05-01 12:13:36 +02:00
|
|
|
extern int get_maxtime(const struct plot_info *pi);
|
2013-05-04 19:20:49 -03:00
|
|
|
|
2021-12-04 21:04:26 +01:00
|
|
|
/* get the maximum depth to which we want to plot */
|
2020-05-01 12:13:36 +02:00
|
|
|
extern int get_maxdepth(const struct plot_info *pi);
|
2013-05-04 19:20:49 -03:00
|
|
|
|
2019-07-06 12:35:33 +02:00
|
|
|
static inline int get_plot_pressure_data(const struct plot_info *pi, int idx, enum plot_pressure sensor, int cylinder)
|
2019-07-05 23:14:07 +02:00
|
|
|
{
|
2020-06-29 20:23:26 +02:00
|
|
|
return pi->pressures[cylinder + idx * pi->nr_cylinders].data[sensor];
|
2019-07-05 23:14:07 +02:00
|
|
|
}
|
|
|
|
|
2019-07-06 12:59:12 +02:00
|
|
|
static inline void set_plot_pressure_data(struct plot_info *pi, int idx, enum plot_pressure sensor, int cylinder, int value)
|
2019-07-05 23:23:20 +02:00
|
|
|
{
|
2020-06-29 20:23:26 +02:00
|
|
|
pi->pressures[cylinder + idx * pi->nr_cylinders].data[sensor] = value;
|
2019-07-05 23:23:20 +02:00
|
|
|
}
|
|
|
|
|
2019-07-06 12:35:33 +02:00
|
|
|
static inline int get_plot_sensor_pressure(const struct plot_info *pi, int idx, int cylinder)
|
2019-07-05 23:14:07 +02:00
|
|
|
{
|
2019-07-06 12:35:33 +02:00
|
|
|
return get_plot_pressure_data(pi, idx, SENSOR_PR, cylinder);
|
2019-07-05 23:14:07 +02:00
|
|
|
}
|
|
|
|
|
2019-07-06 12:35:33 +02:00
|
|
|
static inline int get_plot_interpolated_pressure(const struct plot_info *pi, int idx, int cylinder)
|
2019-07-05 23:14:07 +02:00
|
|
|
{
|
2019-07-06 12:35:33 +02:00
|
|
|
return get_plot_pressure_data(pi, idx, INTERPOLATED_PR, cylinder);
|
2019-07-05 23:14:07 +02:00
|
|
|
}
|
2019-07-05 22:56:27 +02:00
|
|
|
|
2019-07-06 11:58:27 +02:00
|
|
|
static inline int get_plot_pressure(const struct plot_info *pi, int idx, int cylinder)
|
2019-07-05 22:56:27 +02:00
|
|
|
{
|
2019-07-06 12:35:33 +02:00
|
|
|
int res = get_plot_sensor_pressure(pi, idx, cylinder);
|
|
|
|
return res ? res : get_plot_interpolated_pressure(pi, idx, cylinder);
|
2019-07-05 22:56:27 +02:00
|
|
|
}
|
2013-05-09 00:24:03 -03:00
|
|
|
|
2013-05-04 17:24:23 -03:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
2024-03-10 23:11:23 +01:00
|
|
|
|
|
|
|
// C++ only formatting functions
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
// Returns index of sample and array of strings describing the dive details at given time
|
|
|
|
std::pair<int, std::vector<std::string>> get_plot_details_new(const struct dive *d, const struct plot_info *pi, int time);
|
|
|
|
std::vector<std::string> compare_samples(const struct dive *d, const struct plot_info *pi, int idx1, int idx2, bool sum);
|
|
|
|
|
2013-05-04 17:24:23 -03:00
|
|
|
#endif
|
2014-02-11 19:14:46 +01:00
|
|
|
#endif // PROFILE_H
|