|  |  |  | @ -3,7 +3,7 @@ | 
			
		
	
		
			
				
					|  |  |  |  | #include <vector> | 
			
		
	
		
			
				
					|  |  |  |  | #include <string> | 
			
		
	
		
			
				
					|  |  |  |  | #include "svg.h" | 
			
		
	
		
			
				
					|  |  |  |  | #include "text.h" | 
			
		
	
		
			
				
					|  |  |  |  | #include "histogram.h" | 
			
		
	
		
			
				
					|  |  |  |  | using namespace std; | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | void svg_begin(double width, double height) { | 
			
		
	
	
		
			
				
					|  |  |  | @ -27,7 +27,7 @@ void svg_rect(double x, double y, double width, double height, string stroke = " | 
			
		
	
		
			
				
					|  |  |  |  |     cout << "<rect x = '" << x << "' y = '" << y << "' width = '" << width << "' height = '" << height << "' stroke = '" << stroke << "' fill = '" << fill << "' />"; | 
			
		
	
		
			
				
					|  |  |  |  | } | 
			
		
	
		
			
				
					|  |  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |  | void show_histogram_svg(const vector<size_t>& bins) { | 
			
		
	
		
			
				
					|  |  |  |  | void show_histogram_svg(const vector<size_t>& bins, const vector<double>& numbers, size_t& bin_count) { | 
			
		
	
		
			
				
					|  |  |  |  |     const auto IMAGE_WIDTH = 400; | 
			
		
	
		
			
				
					|  |  |  |  |     const auto IMAGE_HEIGHT = 300; | 
			
		
	
		
			
				
					|  |  |  |  |     const auto TEXT_LEFT = 20; | 
			
		
	
	
		
			
				
					|  |  |  | @ -39,9 +39,16 @@ void show_histogram_svg(const vector<size_t>& bins) { | 
			
		
	
		
			
				
					|  |  |  |  |     double top = 0; | 
			
		
	
		
			
				
					|  |  |  |  |     size_t max_bin_capacity{}; | 
			
		
	
		
			
				
					|  |  |  |  |     find_max_capacity(bins, max_bin_capacity); | 
			
		
	
		
			
				
					|  |  |  |  |     for (size_t bin : bins) { | 
			
		
	
		
			
				
					|  |  |  |  |         const double bin_width = (IMAGE_WIDTH - TEXT_WIDTH) * (static_cast<double>(bin) / max_bin_capacity); | 
			
		
	
		
			
				
					|  |  |  |  |         svg_text(TEXT_LEFT, top + TEXT_BASELINE, to_string(bin)); | 
			
		
	
		
			
				
					|  |  |  |  |     double range_border = 0; | 
			
		
	
		
			
				
					|  |  |  |  |     for (size_t i = 0; i < bins.size(); i++) { | 
			
		
	
		
			
				
					|  |  |  |  |         const double bin_width = (IMAGE_WIDTH - TEXT_WIDTH) * (static_cast<double>(bins[i]) / max_bin_capacity); | 
			
		
	
		
			
				
					|  |  |  |  |         if (i != 0) | 
			
		
	
		
			
				
					|  |  |  |  |         { | 
			
		
	
		
			
				
					|  |  |  |  |             find_range_border(numbers, bin_count, i, range_border); | 
			
		
	
		
			
				
					|  |  |  |  |             svg_text(TEXT_LEFT, top + TEXT_BASELINE, to_string(range_border)); | 
			
		
	
		
			
				
					|  |  |  |  |             top += BIN_HEIGHT; | 
			
		
	
		
			
				
					|  |  |  |  |         } | 
			
		
	
		
			
				
					|  |  |  |  |         svg_text(TEXT_LEFT, top + TEXT_BASELINE, to_string(bins[i])); | 
			
		
	
		
			
				
					|  |  |  |  |         svg_rect(TEXT_WIDTH, top, bin_width, BIN_HEIGHT, "purple", "#ffcc00"); | 
			
		
	
		
			
				
					|  |  |  |  |         top += BIN_HEIGHT; | 
			
		
	
		
			
				
					|  |  |  |  |     } | 
			
		
	
	
		
			
				
					|  |  |  | 
 |