2013-05-04 17:24:23 -03:00
|
|
|
#ifndef PROFILE_H
|
|
|
|
#define PROFILE_H
|
|
|
|
|
|
|
|
#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
|
|
|
|
2014-01-18 16:21:13 -08:00
|
|
|
struct membuffer;
|
2013-05-04 17:24:23 -03:00
|
|
|
struct divecomputer;
|
|
|
|
struct plot_info;
|
2013-05-04 19:36:40 -03:00
|
|
|
struct plot_data {
|
2014-02-27 20:09:57 -08:00
|
|
|
unsigned int in_deco : 1;
|
2013-05-10 08:56:56 -07:00
|
|
|
int cylinderindex;
|
2013-05-04 19:36:40 -03:00
|
|
|
int sec;
|
2014-11-18 10:30:24 +01:00
|
|
|
/* pressure[0] is sensor cylinder pressure [when CCR, the pressure of the diluent cylinder]
|
|
|
|
* pressure[1] is interpolated cylinder pressure */
|
2013-05-04 19:36:40 -03:00
|
|
|
int pressure[2];
|
2014-11-18 10:30:24 +01:00
|
|
|
/* o2pressure[0] is o2 cylinder pressure [CCR]
|
|
|
|
* o2pressure[1] is interpolated o2 cylinder pressure [CCR] */
|
2014-11-17 12:25:00 +01:00
|
|
|
int o2cylinderpressure[2];
|
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;
|
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.
|
|
|
|
pressure_t o2sensor[3]; //for rebreathers with up to 3 PO2 sensors
|
2015-01-05 09:20:26 +02:00
|
|
|
pressure_t o2setpoint;
|
2013-05-04 19:36:40 -03:00
|
|
|
double mod, ead, end, eadd;
|
|
|
|
velocity_t velocity;
|
2013-09-25 02:07:07 +02:00
|
|
|
int speed;
|
2013-05-04 19:36:40 -03:00
|
|
|
struct plot_data *min[3];
|
|
|
|
struct plot_data *max[3];
|
|
|
|
int avg[3];
|
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;
|
2013-05-04 19:36:40 -03:00
|
|
|
};
|
2014-08-24 20:48:22 +02:00
|
|
|
|
|
|
|
struct ev_select {
|
|
|
|
char *ev_name;
|
|
|
|
bool plot_ev;
|
|
|
|
};
|
|
|
|
|
2015-01-24 07:05:32 +12:00
|
|
|
struct plot_info calculate_max_limits_new(struct dive *dive, struct divecomputer *given_dc);
|
2013-09-25 02:07:07 +02:00
|
|
|
void compare_samples(struct plot_data *e1, struct plot_data *e2, char *buf, int bufsize, int sum);
|
2014-01-14 16:43:58 -02:00
|
|
|
struct plot_data *populate_plot_entries(struct dive *dive, struct divecomputer *dc, struct plot_info *pi);
|
|
|
|
struct plot_info *analyze_plot_info(struct plot_info *pi);
|
2014-12-04 16:42:00 +01:00
|
|
|
void create_plot_info_new(struct dive *dive, struct divecomputer *dc, struct plot_info *pi, bool fast);
|
2014-02-04 17:34:16 -02:00
|
|
|
void calculate_deco_information(struct dive *dive, struct divecomputer *dc, struct plot_info *pi, bool print_mode);
|
2014-09-19 08:48:19 +02:00
|
|
|
struct plot_data *get_plot_details_new(struct plot_info *pi, int time, struct membuffer *);
|
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
|
|
|
|
*/
|
|
|
|
int get_maxtime(struct plot_info *pi);
|
|
|
|
|
|
|
|
/* get the maximum depth to which we want to plot
|
|
|
|
* take into account the additional verical space needed to plot
|
|
|
|
* partial pressure graphs */
|
|
|
|
int get_maxdepth(struct plot_info *pi);
|
|
|
|
|
2013-05-09 00:24:03 -03:00
|
|
|
#define SENSOR_PR 0
|
|
|
|
#define INTERPOLATED_PR 1
|
|
|
|
#define SENSOR_PRESSURE(_entry) (_entry)->pressure[SENSOR_PR]
|
2014-11-17 12:25:00 +01:00
|
|
|
#define O2CYLINDER_PRESSURE(_entry) (_entry)->o2cylinderpressure[SENSOR_PR]
|
2014-11-17 17:39:40 +01:00
|
|
|
#define CYLINDER_PRESSURE(_o2, _entry) (_o2 ? O2CYLINDER_PRESSURE(_entry) : SENSOR_PRESSURE(_entry))
|
2013-05-09 00:24:03 -03:00
|
|
|
#define INTERPOLATED_PRESSURE(_entry) (_entry)->pressure[INTERPOLATED_PR]
|
2014-11-17 12:25:00 +01:00
|
|
|
#define INTERPOLATED_O2CYLINDER_PRESSURE(_entry) (_entry)->o2cylinderpressure[INTERPOLATED_PR]
|
2013-05-09 00:24:03 -03:00
|
|
|
#define GET_PRESSURE(_entry) (SENSOR_PRESSURE(_entry) ? SENSOR_PRESSURE(_entry) : INTERPOLATED_PRESSURE(_entry))
|
2014-11-17 17:39:40 +01:00
|
|
|
#define GET_O2CYLINDER_PRESSURE(_entry) (O2CYLINDER_PRESSURE(_entry) ? O2CYLINDER_PRESSURE(_entry) : INTERPOLATED_O2CYLINDER_PRESSURE(_entry))
|
2014-02-27 20:09:57 -08:00
|
|
|
#define SAC_WINDOW 45 /* sliding window in seconds for current SAC calculation */
|
2013-05-09 00:24:03 -03:00
|
|
|
|
2013-05-04 17:24:23 -03:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2014-02-11 19:14:46 +01:00
|
|
|
#endif // PROFILE_H
|