aboutsummaryrefslogtreecommitdiffstats
path: root/profile.c
diff options
context:
space:
mode:
authorGravatar willem ferguson <willemferguson@zoology.up.ac.za>2014-10-12 20:46:41 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-10-12 15:23:49 -0400
commitbc9df4652ffe0cc9d6f579bfd66a4857be57d3b2 (patch)
treeea89826fbdda45b4d44aab07d83481dbf34633cb /profile.c
parent6d65e45787cd29c60153d9db0745cdc7bd088f1d (diff)
downloadsubsurface-bc9df4652ffe0cc9d6f579bfd66a4857be57d3b2.tar.gz
CCR patch: Calculate the correct partial gas pressures for CCR dives
This patch adds code to the function fillpressures() in dive.c to allow calculating o2 pressures, based on the data from the po2 sensors in the system. The following changes were made: 1) add code to perform po2 calculations for CCR with 1, 2 or 3 oxygen sesnors. 2) Add four fields to the gas_pressures structure in dive.h. This allows communication of data between the function that calls get_pressures() and the return of partail pressure values to the calling function. 3) Delete the fields for setpoint and gas partial pressures from the structure plot_info. All partial pressures (from instruments as well as calculated) now reside in the pressures structure that forms part of plot_info. 4) Perform changes in several parts of profile.c to make use of the pressures structure in plot_info. [Dirk Hohndel: yet again massive whitespace cleanup] Signed-off-by: willem ferguson <willemferguson@zoology.up.ac.za> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'profile.c')
-rw-r--r--profile.c26
1 files changed, 13 insertions, 13 deletions
diff --git a/profile.c b/profile.c
index 653c5b9dd..10aa9c898 100644
--- a/profile.c
+++ b/profile.c
@@ -553,10 +553,10 @@ struct plot_data *populate_plot_entries(struct dive *dive, struct divecomputer *
entry->in_deco = sample->in_deco;
entry->cns = sample->cns;
entry->pressures.o2 = sample->po2.mbar / 1000.0;
- entry->o2setpoint = sample->o2setpoint.mbar / 1000.0; // for rebreathers
- entry->o2sensor[0] = sample->o2sensor[0].mbar / 1000.0; // for up to three rebreather O2 sensors
- entry->o2sensor[1] = sample->o2sensor[1].mbar / 1000.0;
- entry->o2sensor[2] = sample->o2sensor[2].mbar / 1000.0;
+ entry->pressures.setpoint = sample->o2setpoint.mbar / 1000.0; // for rebreathers
+ entry->pressures.sensor[0] = sample->o2sensor[0].mbar / 1000.0; // for up to three rebreather O2 sensors
+ entry->pressures.sensor[1] = sample->o2sensor[1].mbar / 1000.0;
+ entry->pressures.sensor[2] = sample->o2sensor[2].mbar / 1000.0;
/* FIXME! sensor index -> cylinder index translation! */
entry->cylinderindex = sample->sensor;
@@ -882,21 +882,21 @@ void fill_o2_values(struct divecomputer *dc, struct plot_info *pi)
// For 1st iteration, initialise the last_ values
if (i == 0) {
- last_setpoint = pi->entry->o2setpoint;
+ last_setpoint = pi->entry->pressures.setpoint;
for (j = 0; j < dc->no_o2sensors; j++)
- last_sensor[j] = pi->entry->o2sensor[j];
+ last_sensor[j] = pi->entry->pressures.sensor[j];
} else {
// Now re-insert the missing oxygen pressure values
- if (entry->o2setpoint)
- last_setpoint = entry->o2setpoint;
+ if (entry->pressures.setpoint)
+ last_setpoint = entry->pressures.setpoint;
else
- entry->o2setpoint = last_setpoint;
+ entry->pressures.setpoint = last_setpoint;
for (j = 0; j < dc->no_o2sensors; j++)
- if (entry->o2sensor[j])
- last_sensor[j] = entry->o2sensor[j];
+ if (entry->pressures.sensor[j])
+ last_sensor[j] = entry->pressures.sensor[j];
else
- entry->o2sensor[j] = last_sensor[j];
+ entry->pressures.sensor[j] = last_sensor[j];
}
}
}
@@ -918,7 +918,7 @@ static void debug_print_profiledata(struct plot_info *pi)
entry = pi->entry + i;
fprintf(f1, "%d gas=%8d %8d ; dil=%8d %8d ; o2_sp= %f %f %f %f PO2= %f\n", i, SENSOR_PRESSURE(entry),
INTERPOLATED_PRESSURE(entry), DILUENT_PRESSURE(entry), INTERPOLATED_DILUENT_PRESSURE(entry),
- entry->o2setpoint, entry->o2sensor[0], entry->o2sensor[1], entry->o2sensor[2], entry->pressures.o2);
+ entry->o2setpoint, entry->pressures->sensor[0], entry->pressures->sensor[1], entry->pressures->sensor[2], entry->pressures.o2);
}
fclose(f1);
}