mirror of
				https://github.com/subsurface/subsurface.git
				synced 2025-02-19 22:16:15 +00:00 
			
		
		
		
	Don't interpolate pressure while dragging waypoints
A profiler session in the planner shows that for deep long dives a significant amount of CPU time is spent in populate_pressure_information() which interpolates the cylinder pressure graphs. This patch introduces a "fast" flag for the replot of the profile which is active while the mouse button is still pressed and that suppresses this calculation. In the future, this flag could be used for other responsiveness tunings of the plot. Signed-off-by: Robert C. Helling <helling@atdotde.de> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
		
							parent
							
								
									3e429ac77d
								
							
						
					
					
						commit
						aa22e0610c
					
				
					 3 changed files with 8 additions and 7 deletions
				
			
		
							
								
								
									
										11
									
								
								profile.c
									
										
									
									
									
								
							
							
						
						
									
										11
									
								
								profile.c
									
										
									
									
									
								
							|  | @ -1028,7 +1028,7 @@ static void debug_print_profiledata(struct plot_info *pi) | ||||||
|  * sides, so that you can do end-points without having to worry |  * sides, so that you can do end-points without having to worry | ||||||
|  * about it. |  * about it. | ||||||
|  */ |  */ | ||||||
| void create_plot_info_new(struct dive *dive, struct divecomputer *dc, struct plot_info *pi) | void create_plot_info_new(struct dive *dive, struct divecomputer *dc, struct plot_info *pi, bool fast) | ||||||
| { | { | ||||||
| 	int o2, he, o2low; | 	int o2, he, o2low; | ||||||
| 	init_decompression(dive); | 	init_decompression(dive); | ||||||
|  | @ -1049,10 +1049,11 @@ void create_plot_info_new(struct dive *dive, struct divecomputer *dc, struct plo | ||||||
| 	check_gas_change_events(dive, dc, pi);			/* Populate the gas index from the gas change events */ | 	check_gas_change_events(dive, dc, pi);			/* Populate the gas index from the gas change events */ | ||||||
| 	check_setpoint_events(dive, dc, pi);			/* Populate setpoints */ | 	check_setpoint_events(dive, dc, pi);			/* Populate setpoints */ | ||||||
| 	setup_gas_sensor_pressure(dive, dc, pi);		/* Try to populate our gas pressure knowledge */ | 	setup_gas_sensor_pressure(dive, dc, pi);		/* Try to populate our gas pressure knowledge */ | ||||||
| 	populate_pressure_information(dive, dc, pi, false);	/* .. calculate missing pressure entries for all gasses except o2 */ | 	if (!fast) { | ||||||
| 	if (dc->dctype == CCR)					/* For CCR dives.. */ | 		populate_pressure_information(dive, dc, pi, false);	/* .. calculate missing pressure entries for all gasses except o2 */ | ||||||
| 		populate_pressure_information(dive, dc, pi, true); /* .. calculate missing o2 gas pressure entries */ | 		if (dc->dctype == CCR)					/* For CCR dives.. */ | ||||||
| 
 | 			populate_pressure_information(dive, dc, pi, true); /* .. calculate missing o2 gas pressure entries */ | ||||||
|  | 	} | ||||||
| 	fill_o2_values(dc, pi, dive);				/* .. and insert the O2 sensor data having 0 values. */ | 	fill_o2_values(dc, pi, dive);				/* .. and insert the O2 sensor data having 0 values. */ | ||||||
| 	calculate_sac(dive, pi); /* Calculate sac */ | 	calculate_sac(dive, pi); /* Calculate sac */ | ||||||
| 	calculate_deco_information(dive, dc, pi, false); /* and ceiling information, using gradient factor values in Preferences) */ | 	calculate_deco_information(dive, dc, pi, false); /* and ceiling information, using gradient factor values in Preferences) */ | ||||||
|  |  | ||||||
|  | @ -70,7 +70,7 @@ struct plot_info calculate_max_limits_new(struct dive *dive, struct divecomputer | ||||||
| void compare_samples(struct plot_data *e1, struct plot_data *e2, char *buf, int bufsize, int sum); | void compare_samples(struct plot_data *e1, struct plot_data *e2, char *buf, int bufsize, int sum); | ||||||
| struct plot_data *populate_plot_entries(struct dive *dive, struct divecomputer *dc, struct plot_info *pi); | 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); | struct plot_info *analyze_plot_info(struct plot_info *pi); | ||||||
| void create_plot_info_new(struct dive *dive, struct divecomputer *dc, struct plot_info *pi); | void create_plot_info_new(struct dive *dive, struct divecomputer *dc, struct plot_info *pi, bool fast); | ||||||
| void calculate_deco_information(struct dive *dive, struct divecomputer *dc, struct plot_info *pi, bool print_mode); | void calculate_deco_information(struct dive *dive, struct divecomputer *dc, struct plot_info *pi, bool print_mode); | ||||||
| struct plot_data *get_plot_details_new(struct plot_info *pi, int time, struct membuffer *); | struct plot_data *get_plot_details_new(struct plot_info *pi, int time, struct membuffer *); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -492,7 +492,7 @@ void ProfileWidget2::plotDive(struct dive *d, bool force) | ||||||
| 	 * shown. | 	 * shown. | ||||||
| 	 */ | 	 */ | ||||||
| 	plotInfo = calculate_max_limits_new(&displayed_dive, currentdc); | 	plotInfo = calculate_max_limits_new(&displayed_dive, currentdc); | ||||||
| 	create_plot_info_new(&displayed_dive, currentdc, &plotInfo); | 	create_plot_info_new(&displayed_dive, currentdc, &plotInfo, !shouldCalculateMaxDepth); | ||||||
| 	if(shouldCalculateMaxTime) | 	if(shouldCalculateMaxTime) | ||||||
| 		maxtime = get_maxtime(&plotInfo); | 		maxtime = get_maxtime(&plotInfo); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue