mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 09:11:23 -06:00 
			
		
		
		
	Merge branch 'master' of https://github.com/prusa3d/PrusaSlicer into et_plater_thumbnail
This commit is contained in:
		
						commit
						d8dca69d60
					
				
					 7 changed files with 201 additions and 9 deletions
				
			
		|  | @ -167,6 +167,7 @@ int CLI::run(int argc, char **argv) | |||
| //    sla_print_config.apply(m_print_config, true);
 | ||||
| 
 | ||||
|     // Loop through transform options.
 | ||||
|     bool user_center_specified = false; | ||||
|     for (auto const &opt_key : m_transforms) { | ||||
|         if (opt_key == "merge") { | ||||
|             Model m; | ||||
|  | @ -209,6 +210,7 @@ int CLI::run(int argc, char **argv) | |||
|             for (auto &model : m_models) | ||||
|                 model.duplicate_objects_grid(x, y, (distance > 0) ? distance : 6);  // TODO: this is not the right place for setting a default
 | ||||
|         } else if (opt_key == "center") { | ||||
|         	user_center_specified = true; | ||||
|             for (auto &model : m_models) { | ||||
|                 model.add_default_instances(); | ||||
|                 // this affects instances:
 | ||||
|  | @ -403,7 +405,9 @@ int CLI::run(int argc, char **argv) | |||
|                 if (! m_config.opt_bool("dont_arrange")) { | ||||
|                     //FIXME make the min_object_distance configurable.
 | ||||
|                     model.arrange_objects(fff_print.config().min_object_distance()); | ||||
|                     model.center_instances_around_point(m_config.option<ConfigOptionPoint>("center")->value); | ||||
|                     model.center_instances_around_point((! user_center_specified && m_print_config.has("bed_shape")) ?  | ||||
|                     	BoundingBoxf(m_print_config.opt<ConfigOptionPoints>("bed_shape")->values).center() :  | ||||
|                     	m_config.option<ConfigOptionPoint>("center")->value); | ||||
|                 } | ||||
|                 if (printer_technology == ptFFF) { | ||||
|                     for (auto* mo : model.objects) | ||||
|  |  | |||
|  | @ -267,6 +267,99 @@ static inline void smooth_compensation(std::vector<float> &compensation, float s | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| template<typename INDEX_TYPE, typename CONTAINER> | ||||
| static inline INDEX_TYPE prev_idx_cyclic(INDEX_TYPE idx, const CONTAINER &container) | ||||
| { | ||||
| 	if (idx == 0) | ||||
| 		idx = INDEX_TYPE(container.size()); | ||||
| 	return -- idx; | ||||
| } | ||||
| 
 | ||||
| template<typename INDEX_TYPE, typename CONTAINER> | ||||
| static inline INDEX_TYPE next_idx_cyclic(INDEX_TYPE idx, const CONTAINER &container) | ||||
| { | ||||
| 	if (++ idx == INDEX_TYPE(container.size())) | ||||
| 		idx = 0; | ||||
| 	return idx; | ||||
| } | ||||
| 
 | ||||
| template<class T, class U = T> | ||||
| static inline T exchange(T& obj, U&& new_value) | ||||
| { | ||||
|     T old_value = std::move(obj); | ||||
|     obj = std::forward<U>(new_value); | ||||
|     return old_value; | ||||
| } | ||||
| 
 | ||||
| static inline void smooth_compensation_banded(const Points &contour, float band, std::vector<float> &compensation, float strength, size_t num_iterations) | ||||
| { | ||||
| 	assert(contour.size() == compensation.size()); | ||||
| 	assert(contour.size() > 2); | ||||
| 	std::vector<float> out(compensation); | ||||
| 	float dist_min2 = band * band; | ||||
| 	static constexpr bool use_min = false; | ||||
| 	for (size_t iter = 0; iter < num_iterations; ++ iter) { | ||||
| 		for (int i = 0; i < int(compensation.size()); ++ i) { | ||||
| 			const Vec2f  pthis = contour[i].cast<float>(); | ||||
| 			 | ||||
| 			int		j     = prev_idx_cyclic(i, contour); | ||||
| 			Vec2f	pprev = contour[j].cast<float>(); | ||||
| 			float	prev  = compensation[j]; | ||||
| 			float	l2    = (pthis - pprev).squaredNorm(); | ||||
| 			if (l2 < dist_min2) { | ||||
| 				float l = sqrt(l2); | ||||
| 				int jprev = exchange(j, prev_idx_cyclic(j, contour)); | ||||
| 				while (j != i) { | ||||
| 					const Vec2f pp = contour[j].cast<float>(); | ||||
| 					const float lthis = (pp - pprev).norm(); | ||||
| 					const float lnext = l + lthis; | ||||
| 					if (lnext > band) { | ||||
| 						// Interpolate the compensation value.
 | ||||
| 						prev = use_min ? | ||||
| 							std::min(prev, lerp(compensation[jprev], compensation[j], (band - l) / lthis)) : | ||||
| 							lerp(compensation[jprev], compensation[j], (band - l) / lthis); | ||||
| 						break; | ||||
| 					} | ||||
| 					prev  = use_min ? std::min(prev, compensation[j]) : compensation[j]; | ||||
| 					pprev = pp; | ||||
| 					l     = lnext; | ||||
| 					jprev = exchange(j, prev_idx_cyclic(j, contour)); | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
| 			j = next_idx_cyclic(i, contour); | ||||
| 			pprev = contour[j].cast<float>(); | ||||
| 			float next = compensation[j]; | ||||
| 			l2 = (pprev - pthis).squaredNorm(); | ||||
| 			if (l2 < dist_min2) { | ||||
| 				float l = sqrt(l2); | ||||
| 				int jprev = exchange(j, next_idx_cyclic(j, contour)); | ||||
| 				while (j != i) { | ||||
| 					const Vec2f pp = contour[j].cast<float>(); | ||||
| 					const float lthis = (pp - pprev).norm(); | ||||
| 					const float lnext = l + lthis; | ||||
| 					if (lnext > band) { | ||||
| 						// Interpolate the compensation value.
 | ||||
| 						next = use_min ? | ||||
| 							std::min(next, lerp(compensation[jprev], compensation[j], (band - l) / lthis)) : | ||||
| 							lerp(compensation[jprev], compensation[j], (band - l) / lthis); | ||||
| 						break; | ||||
| 					} | ||||
| 					next  = use_min ? std::min(next, compensation[j]) : compensation[j]; | ||||
| 					pprev = pp; | ||||
| 					l     = lnext; | ||||
| 					jprev = exchange(j, next_idx_cyclic(j, contour)); | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
| 			float laplacian = compensation[i] * (1.f - strength) + 0.5f * strength * (prev + next); | ||||
| 			// Compensations are negative. Only apply the laplacian if it leads to lower compensation.
 | ||||
| 			out[i] = std::max(laplacian, compensation[i]); | ||||
| 		} | ||||
| 		out.swap(compensation); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| ExPolygon elephant_foot_compensation(const ExPolygon &input_expoly, const Flow &external_perimeter_flow, const double compensation) | ||||
| { | ||||
| 	// The contour shall be wide enough to apply the external perimeter plus compensation on both sides.
 | ||||
|  | @ -285,10 +378,11 @@ ExPolygon elephant_foot_compensation(const ExPolygon &input_expoly, const Flow & | |||
| 	std::vector<std::vector<float>> deltas; | ||||
| 	deltas.reserve(simplified.holes.size() + 1); | ||||
| 	ExPolygon resampled(simplified); | ||||
| 	double resample_interval = scale_(0.5); | ||||
| 	for (size_t idx_contour = 0; idx_contour <= simplified.holes.size(); ++ idx_contour) { | ||||
| 		Polygon &poly = (idx_contour == 0) ? resampled.contour : resampled.holes[idx_contour - 1]; | ||||
| 		std::vector<ResampledPoint> resampled_point_parameters; | ||||
| 		poly.points = resample_polygon(poly.points, scale_(0.5), resampled_point_parameters); | ||||
| 		poly.points = resample_polygon(poly.points, resample_interval, resampled_point_parameters); | ||||
| 		std::vector<float> dists = contour_distance(grid, idx_contour, poly.points, resampled_point_parameters, search_radius); | ||||
| 		for (float &d : dists) { | ||||
| //			printf("Point %d, Distance: %lf\n", int(&d - dists.data()), unscale<double>(d));
 | ||||
|  | @ -301,7 +395,8 @@ ExPolygon elephant_foot_compensation(const ExPolygon &input_expoly, const Flow & | |||
| 				d = - (d - float(min_contour_width)) / 2.f; | ||||
| 			assert(d >= - float(scaled_compensation) && d <= 0.f); | ||||
| 		} | ||||
| 		smooth_compensation(dists, 0.4f, 10); | ||||
| //		smooth_compensation(dists, 0.4f, 10);
 | ||||
| 		smooth_compensation_banded(poly.points, float(0.8 * resample_interval), dists, 0.3f, 3); | ||||
| 		deltas.emplace_back(dists); | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
|  | @ -1068,6 +1068,9 @@ void GCode::_do_export(Print &print, FILE *file) | |||
|             _writeln(file, GCodeTimeEstimator::Silent_First_M73_Output_Placeholder_Tag); | ||||
|     } | ||||
| 
 | ||||
| 	// Hold total number of print toolchanges. Check for negative toolchanges (single extruder mode) and set to 0 (no tool change).
 | ||||
|     int total_toolchanges = std::max(0, print.wipe_tower_data().number_of_toolchanges); | ||||
| 
 | ||||
|     // Prepare the helper object for replacing placeholders in custom G-code and output filename.
 | ||||
|     m_placeholder_parser = print.placeholder_parser(); | ||||
|     m_placeholder_parser.update_timestamp(); | ||||
|  | @ -1130,6 +1133,7 @@ void GCode::_do_export(Print &print, FILE *file) | |||
|     // For the start / end G-code to do the priming and final filament pull in case there is no wipe tower provided.
 | ||||
|     m_placeholder_parser.set("has_wipe_tower", has_wipe_tower); | ||||
|     m_placeholder_parser.set("has_single_extruder_multi_material_priming", has_wipe_tower && print.config().single_extruder_multi_material_priming); | ||||
|     m_placeholder_parser.set("total_toolchanges", total_toolchanges); | ||||
|     std::string start_gcode = this->placeholder_parser_process("start_gcode", print.config().start_gcode.value, initial_extruder_id); | ||||
|     // Set bed temperature if the start G-code does not contain any bed temp control G-codes.
 | ||||
|     this->_print_first_layer_bed_temperature(file, print, start_gcode, initial_extruder_id, true); | ||||
|  | @ -1380,7 +1384,7 @@ void GCode::_do_export(Print &print, FILE *file) | |||
|     print.m_print_statistics.estimated_normal_color_print_times = m_normal_time_estimator.get_color_times_dhms(true); | ||||
|     if (m_silent_time_estimator_enabled) | ||||
|         print.m_print_statistics.estimated_silent_color_print_times = m_silent_time_estimator.get_color_times_dhms(true); | ||||
| 
 | ||||
|     print.m_print_statistics.total_toolchanges = total_toolchanges; | ||||
|     std::vector<Extruder> extruders = m_writer.extruders(); | ||||
|     if (! extruders.empty()) { | ||||
|         std::pair<std::string, unsigned int> out_filament_used_mm ("; filament used [mm] = ", 0); | ||||
|  | @ -1430,6 +1434,8 @@ void GCode::_do_export(Print &print, FILE *file) | |||
|     } | ||||
|     _write_format(file, "; total filament used [g] = %.1lf\n", print.m_print_statistics.total_weight); | ||||
|     _write_format(file, "; total filament cost = %.1lf\n", print.m_print_statistics.total_cost); | ||||
|     if (print.m_print_statistics.total_toolchanges > 0) | ||||
|     	_write_format(file, "; total toolchanges = %i\n", print.m_print_statistics.total_toolchanges); | ||||
|     _write_format(file, "; estimated printing time (normal mode) = %s\n", m_normal_time_estimator.get_time_dhms().c_str()); | ||||
|     if (m_silent_time_estimator_enabled) | ||||
|         _write_format(file, "; estimated printing time (silent mode) = %s\n", m_silent_time_estimator.get_time_dhms().c_str()); | ||||
|  |  | |||
|  | @ -2064,6 +2064,7 @@ DynamicConfig PrintStatistics::config() const | |||
|     config.set_key_value("used_filament",             new ConfigOptionFloat (this->total_used_filament / 1000.)); | ||||
|     config.set_key_value("extruded_volume",           new ConfigOptionFloat (this->total_extruded_volume)); | ||||
|     config.set_key_value("total_cost",                new ConfigOptionFloat (this->total_cost)); | ||||
|     config.set_key_value("total_toolchanges",         new ConfigOptionInt(this->total_toolchanges)); | ||||
|     config.set_key_value("total_weight",              new ConfigOptionFloat (this->total_weight)); | ||||
|     config.set_key_value("total_wipe_tower_cost",     new ConfigOptionFloat (this->total_wipe_tower_cost)); | ||||
|     config.set_key_value("total_wipe_tower_filament", new ConfigOptionFloat (this->total_wipe_tower_filament)); | ||||
|  | @ -2076,7 +2077,7 @@ DynamicConfig PrintStatistics::placeholders() | |||
|     for (const std::string &key : {  | ||||
|         "print_time", "normal_print_time", "silent_print_time",  | ||||
|         "used_filament", "extruded_volume", "total_cost", "total_weight",  | ||||
|         "total_wipe_tower_cost", "total_wipe_tower_filament"}) | ||||
|         "total_toolchanges", "total_wipe_tower_cost", "total_wipe_tower_filament"}) | ||||
|         config.set_key_value(key, new ConfigOptionString(std::string("{") + key + "}")); | ||||
|     return config; | ||||
| } | ||||
|  |  | |||
|  | @ -253,6 +253,7 @@ struct PrintStatistics | |||
|     double                          total_used_filament; | ||||
|     double                          total_extruded_volume; | ||||
|     double                          total_cost; | ||||
|     int                             total_toolchanges; | ||||
|     double                          total_weight; | ||||
|     double                          total_wipe_tower_cost; | ||||
|     double                          total_wipe_tower_filament; | ||||
|  | @ -273,6 +274,7 @@ struct PrintStatistics | |||
|         total_used_filament    = 0.; | ||||
|         total_extruded_volume  = 0.; | ||||
|         total_cost             = 0.; | ||||
|         total_toolchanges      = 0; | ||||
|         total_weight           = 0.; | ||||
|         total_wipe_tower_cost  = 0.; | ||||
|         total_wipe_tower_filament = 0.; | ||||
|  |  | |||
|  | @ -183,7 +183,7 @@ void ObjectInfo::msw_rescale() | |||
|     manifold_warning_icon->SetBitmap(create_scaled_bitmap(nullptr, "exclamation")); | ||||
| } | ||||
| 
 | ||||
| enum SlisedInfoIdx | ||||
| enum SlicedInfoIdx | ||||
| { | ||||
|     siFilament_m, | ||||
|     siFilament_mm3, | ||||
|  | @ -200,7 +200,7 @@ class SlicedInfo : public wxStaticBoxSizer | |||
| { | ||||
| public: | ||||
|     SlicedInfo(wxWindow *parent); | ||||
|     void SetTextAndShow(SlisedInfoIdx idx, const wxString& text, const wxString& new_label=""); | ||||
|     void SetTextAndShow(SlicedInfoIdx idx, const wxString& text, const wxString& new_label=""); | ||||
| 
 | ||||
| private: | ||||
|     std::vector<std::pair<wxStaticText*, wxStaticText*>> info_vec; | ||||
|  | @ -238,7 +238,7 @@ SlicedInfo::SlicedInfo(wxWindow *parent) : | |||
|     this->Show(false); | ||||
| } | ||||
| 
 | ||||
| void SlicedInfo::SetTextAndShow(SlisedInfoIdx idx, const wxString& text, const wxString& new_label/*=""*/) | ||||
| void SlicedInfo::SetTextAndShow(SlicedInfoIdx idx, const wxString& text, const wxString& new_label/*=""*/) | ||||
| { | ||||
|     const bool show = text != "N/A"; | ||||
|     if (show) | ||||
|  | @ -1217,7 +1217,7 @@ void Sidebar::show_sliced_info_sizer(const bool show) | |||
|             } | ||||
| 
 | ||||
|             // if there is a wipe tower, insert number of toolchanges info into the array:
 | ||||
|             p->sliced_info->SetTextAndShow(siWTNumbetOfToolchanges, is_wipe_tower ? wxString::Format("%.d", p->plater->fff_print().wipe_tower_data().number_of_toolchanges) : "N/A"); | ||||
|             p->sliced_info->SetTextAndShow(siWTNumbetOfToolchanges, is_wipe_tower ? wxString::Format("%.d", ps.total_toolchanges) : "N/A"); | ||||
| 
 | ||||
|             // Hide non-FFF sliced info parameters
 | ||||
|             p->sliced_info->SetTextAndShow(siMateril_unit, "N/A"); | ||||
|  |  | |||
|  | @ -151,6 +151,75 @@ static ExPolygon thin_ring() | |||
| 	return out; | ||||
| } | ||||
| 
 | ||||
| static ExPolygon vase_with_fins() | ||||
| { | ||||
| 	ExPolygon out; | ||||
| 	out.contour.points = { | ||||
| 		{27431106, 489754}, {27436907, 489850}, {27457500, 489724}, {27457500, 5510510}, {28343327, 5565859}, {28351400, 5566288}, {28389945, 5568336}, {28394790, 5568765}, {28420177, 5571613}, {28901163, 5629918},  | ||||
| 		{29903776, 5750412}, {30416384, 2513976}, {30682801, 831878}, {30688548, 795593}, {31507808, 939183}, {31513523, 940185}, {31533883, 943282}, {30775577, 5731079}, {30768824, 5773720}, {30748466, 5902252},  | ||||
| 		{31614726, 6095505}, {31622633, 6097191}, {31660382, 6105244}, {31665100, 6106426}, {31689729, 6113210}, {32155671, 6246039}, {33127094, 6521893}, {34139670, 3405493}, {34665944, 1785782}, {34677296, 1750843},  | ||||
| 		{35464012, 2020824}, {35469500, 2022707}, {35489124, 2028950}, {33991170, 6639179}, {33977829, 6680238}, {33937615, 6804003}, {34762987, 7130382}, {34770532, 7133285}, {34806557, 7147144}, {34811033, 7149049},  | ||||
| 		{34834297, 7159603}, {35273721, 7363683}, {36190026, 7788101}, {37677657, 4868472}, {38450834, 3351031}, {38467513, 3318298}, {39202308, 3708028}, {39207434, 3710747}, {39225840, 3719984}, {37025125, 8039112},  | ||||
| 		{37005525, 8077579}, {36946446, 8193529}, {37710592, 8645011}, {37717591, 8649059}, {37751004, 8668383}, {37755126, 8670965}, {37776453, 8685028}, {38178545, 8955338}, {39017176, 9517879}, {40943217, 6866906},  | ||||
| 		{41944249, 5489097}, {41965843, 5459376}, {42630625, 5959265}, {42635262, 5962752}, {42651996, 5974755}, {39802725, 9896448}, {39777349, 9931375}, {39700858, 10036656}, {40384973, 10602104}, {40391252, 10607196},  | ||||
| 		{40421232, 10631509}, {40424899, 10634704}, {40443764, 10651931}, {40798616, 10981815}, {41538921, 11668622}, {43855948, 9351592}, {45060194, 8147345}, {45086172, 8121368}, {45664563, 8719082}, {45668598, 8723251},  | ||||
| 		{45683249, 8737724}, {42255579, 12165422}, {42225051, 12195949}, {42133032, 12287968}, {42720262, 12953467}, {42725667, 12959479}, {42751474, 12988183}, {42754596, 12991912}, {42770534, 13011877}, {43069412, 13393211},  | ||||
| 		{43693167, 14187377}, {46344137, 12261333}, {47721948, 11260299}, {47751670, 11238705}, {48229435, 11919543}, {48232767, 11924292}, {48244974, 11940879}, {44323286, 14790155}, {44288359, 14815531}, {44183078, 14892022},  | ||||
| 		{44658973, 15641210}, {44663371, 15647994}, {44684370, 15680381}, {44686871, 15684553}, {44699489, 15706766}, {44935035, 16130156}, {45426863, 17012121}, {48346505, 15524481}, {49863946, 14751306}, {49896680, 14734627},  | ||||
| 		{50262068, 15481841}, {50264616, 15487053}, {50274078, 15505344}, {45954933, 17706046}, {45916466, 17725646}, {45800515, 17784726}, {46153358, 18599135}, {46156641, 18606523}, {46172315, 18641796}, {46174132, 18646308},  | ||||
| 		{46183120, 18670221}, {46349534, 19125250}, {46697342, 20073284}, {49813754, 19060715}, {51433464, 18534440}, {51468404, 18523087}, {51712400, 19318239}, {51714102, 19323786}, {51720585, 19343332}, {47110355, 20841293},  | ||||
| 		{47069295, 20854634}, {46945530, 20894847}, {47166614, 21754409}, {47168701, 21762220}, {47178664, 21799510}, {47179753, 21804251}, {47184889, 21829276}, {47278074, 22304738}, {47473309, 23295520}, {50709741, 22782917},  | ||||
| 		{52391837, 22516497}, {52428122, 22510750}, {52544737, 23334291}, {52545550, 23340036}, {52548897, 23360356}, {47761090, 24118668}, {47718449, 24125422}, {47589917, 24145780}, {47673812, 25029360}, {47674651, 25037401},  | ||||
| 		{47678657, 25075792}, {47678992, 25080644}, {47680151, 25106164}, {47697809, 25590347}, {47735642, 26599468}, {52752230, 26599468}, {52738564, 27431106}, {52738469, 27436907}, {52738595, 27457500}, {47717808, 27457500},  | ||||
| 		{47662461, 28343321}, {47662032, 28351394}, {47659983, 28389938}, {47659554, 28394784}, {47656706, 28420171}, {47598401, 28901157}, {47477907, 29903774}, {50714338, 30416378}, {52396434, 30682795}, {52432719, 30688542},  | ||||
| 		{52289144, 31507800}, {52288143, 31513515}, {52285046, 31533875}, {47497239, 30775569}, {47454598, 30768816}, {47326067, 30748458}, {47132809, 31614720}, {47131122, 31622626}, {47123069, 31660376}, {47121887, 31665094},  | ||||
| 		{47115103, 31689724}, {46982279, 32155664}, {46706424, 33127087}, {49822834, 34139662}, {51442545, 34665936}, {51477485, 34677289}, {51207490, 35464012}, {51205607, 35469500}, {51199363, 35489124}, {46589140, 33991162},  | ||||
| 		{46548081, 33977821}, {46424316, 33937607}, {46097945, 34762979}, {46095042, 34770524}, {46081183, 34806549}, {46079278, 34811025}, {46068724, 34834289}, {45864641, 35273715}, {45440218, 36190023}, {48359847, 37677651},  | ||||
| 		{49877288, 38450826}, {49910022, 38467505}, {49520291, 39202300}, {49517572, 39207426}, {49508336, 39225832}, {45189199, 37025117}, {45150732, 37005517}, {45034781, 36946438}, {44583309, 37710592}, {44579262, 37717591},  | ||||
| 		{44559938, 37751004}, {44557356, 37755126}, {44543292, 37776453}, {44272982, 38178543}, {43710441, 39017170}, {46361413, 40943214}, {47739222, 41944249}, {47768943, 41965843}, {47269053, 42630624}, {47265566, 42635262},  | ||||
| 		{47253564, 42651996}, {43331872, 39802717}, {43296945, 39777341}, {43191664, 39700850}, {42626221, 40384973}, {42621129, 40391252}, {42596816, 40421232}, {42593621, 40424899}, {42576394, 40443764}, {42246510, 40798616},  | ||||
| 		{41559699, 41538918}, {43876735, 43855948}, {45080983, 45060194}, {45106960, 45086172}, {44509231, 45664571}, {44505061, 45668605}, {44490589, 45683256}, {41062903, 42255578}, {40940357, 42133032}, {40274856, 42720258},  | ||||
| 		{40268844, 42725663}, {40240140, 42751470}, {40236411, 42754592}, {40216446, 42770530}, {39835112, 43069407}, {39040953, 43693161}, {40966991, 46344124}, {41968025, 47721932}, {41989619, 47751654}, {41308783, 48229434},  | ||||
| 		{41304034, 48232767}, {41287447, 48244973}, {38438168, 44323278}, {38412792, 44288351}, {38336302, 44183071}, {37587122, 44658973}, {37580338, 44663371}, {37547951, 44684370}, {37543779, 44686871}, {37521566, 44699489},  | ||||
| 		{37098171, 44935029}, {36216213, 45426864}, {37703841, 48346500}, {38477019, 49863946}, {38493698, 49896680}, {37746484, 50262052}, {37741272, 50264600}, {37722981, 50274062}, {35522285, 45954933}, {35502686, 45916466},  | ||||
| 		{35443606, 45800515}, {34629191, 46153350}, {34621803, 46156633}, {34586530, 46172307}, {34582018, 46174124}, {34558105, 46183112}, {34103078, 46349526}, {33155041, 46697341}, {34167619, 49813746}, {34693894, 51433456},  | ||||
| 		{34705246, 51468395}, {33910086, 51712399}, {33904540, 51714102}, {33884994, 51720585}, {32387039, 47110355}, {32373698, 47069295}, {32333485, 46945530}, {31473915, 47166622}, {31466104, 47168709}, {31428813, 47178672},  | ||||
| 		{31424073, 47179760}, {31399048, 47184897}, {30923586, 47278079}, {29932800, 47473310}, {30445407, 50709741}, {30711827, 52391837}, {30717574, 52428122}, {29894033, 52544729}, {29888288, 52545543}, {29867968, 52548889},  | ||||
| 		{29109657, 47761082}, {29102904, 47718441}, {29082546, 47589909}, {28198964, 47673827}, {28190923, 47674666}, {28152532, 47678673}, {28147680, 47679007}, {28122160, 47680166}, {27637977, 47697820}, {26628861, 47735648},  | ||||
| 		{26628861, 51012422}, {26628864, 52715485}, {26628864, 52752222}, {25797210, 52738556}, {25791409, 52738461}, {25770816, 52738587}, {25770816, 47717800}, {24884998, 47662453}, {24876924, 47662024}, {24838380, 47659975},  | ||||
| 		{24833534, 47659546}, {24808147, 47656698}, {24327161, 47598396}, {23324548, 47477901}, {22811940, 50714338}, {22545523, 52396434}, {22539776, 52432719}, {21720525, 52289129}, {21714811, 52288127}, {21694451, 52285030},  | ||||
| 		{22452755, 47497223}, {22459508, 47454583}, {22479866, 47326051}, {21613606, 47132816}, {21605699, 47131129}, {21567950, 47123077}, {21563232, 47121895}, {21538602, 47115110}, {21072662, 46982279}, {20101239, 46706425},  | ||||
| 		{19088664, 49822824}, {18562390, 51442538}, {18551037, 51477477}, {17764314, 51207498}, {17758826, 51205614}, {17739202, 51199371}, {19237154, 46589140}, {19250495, 46548081}, {19290709, 46424316}, {18465339, 46097937},  | ||||
| 		{18457794, 46095035}, {18421769, 46081175}, {18417293, 46079270}, {18394029, 46068716}, {17954603, 45864634}, {17038299, 45440211}, {15550671, 48359845}, {14777498, 49877288}, {14760820, 49910022}, {14026023, 49520291},  | ||||
| 		{14020897, 49517572}, {14002491, 49508335}, {16203201, 45189191}, {16222801, 45150724}, {16281880, 45034773}, {15517740, 44583309}, {15510741, 44579261}, {15477328, 44559938}, {15473206, 44557356}, {15451878, 44543292},  | ||||
| 		{15049787, 44272982}, {14211153, 43710440}, {12285115, 46361403}, {11284082, 47739206}, {11262488, 47768928}, {10597703, 47269053}, {10593066, 47265566}, {10576332, 47253563}, {13425609, 43331872}, {13450985, 43296945},  | ||||
| 		{13527476, 43191664}, {12843352, 42626213}, {12837073, 42621121}, {12807093, 42596808}, {12803426, 42593613}, {12784561, 42576386}, {12429709, 42246502}, {11689410, 41559693}, {9372373, 43876727}, {8168126, 45080975},  | ||||
| 		{8142148, 45106952}, {7563757, 44509222}, {7559722, 44505053}, {7545071, 44490581}, {10972747, 41062911}, {11003274, 41032383}, {11095293, 40940365}, {10508063, 40274848}, {10502658, 40268836}, {10476851, 40240132},  | ||||
| 		{10473729, 40236403}, {10457791, 40216438}, {10158911, 39835107}, {9535160, 39040950}, {6884192, 40966991}, {5506386, 41968025}, {5476665, 41989618}, {4998885, 41308775}, {4995553, 41304026}, {4983346, 41287439},  | ||||
| 		{8905039, 38438168}, {8939966, 38412792}, {9045247, 38336301}, {8569356, 37587114}, {8564958, 37580330}, {8543959, 37547943}, {8541458, 37543771}, {8528840, 37521558}, {8293293, 37098166}, {7801454, 36216208},  | ||||
| 		{4881822, 37703836}, {3364381, 38477011}, {3331647, 38493690}, {2966260, 37746484}, {2963712, 37741272}, {2954250, 37722981}, {7273379, 35522270}, {7311845, 35502670}, {7427796, 35443590}, {7074968, 34629191},  | ||||
| 		{7071686, 34621803}, {7056012, 34586530}, {7054194, 34582018}, {7045206, 34558105}, {6878792, 34103076}, {6530980, 33155036}, {3414573, 34167611}, {1794864, 34693885}, {1759924, 34705238}, {1515921, 33910079},  | ||||
| 		{1514219, 33904532}, {1507735, 33884986}, {6117964, 32387033}, {6159023, 32373692}, {6282789, 32333479}, {6061704, 31473909}, {6059617, 31466099}, {6049654, 31428807}, {6048565, 31424067}, {6043429, 31399042},  | ||||
| 		{5950245, 30923582}, {5755014, 29932799}, {2518579, 30445403}, {836483, 30711821}, {800198, 30717568}, {683591, 29894033}, {682777, 29888288}, {679431, 29867968}, {5467236, 29109657}, {5509877, 29102904}, {5638409, 29082546},  | ||||
| 		{5554499, 28198964}, {5553660, 28190923}, {5549653, 28152532}, {5549319, 28147680}, {5548160, 28122159}, {5530507, 27637975}, {5492679, 26628853}, {2215900, 26628853}, {512834, 26628856}, {476096, 26628856}, {489754, 25797218}, | ||||
| 		{489850, 25791417}, {489724, 25770824}, {5510510, 25770824}, {5565867, 24884990}, {5566296, 24876916}, {5568344, 24838372}, {5568773, 24833527}, {5571621, 24808139}, {5629923, 24327156}, {5750418, 23324543}, {2513981, 22811940},  | ||||
| 		{831886, 22545523}, {795600, 22539776}, {939191, 21720518}, {940192, 21714803}, {943289, 21694443}, {5731087, 22452754}, {5773728, 22459508}, {5902260, 22479865}, {6095512, 21613598}, {6097199, 21605691}, {6105252, 21567942},  | ||||
| 		{6106434, 21563224}, {6113218, 21538594}, {6246044, 21072654}, {6521898, 20101231}, {3405493, 19088662}, {1785783, 18562390}, {1750843, 18551037}, {2020831, 17764306}, {2022714, 17758819}, {2028958, 17739194}, {6639187, 19237147},  | ||||
| 		{6680246, 19250488}, {6804011, 19290701}, {7130382, 18465339}, {7133285, 18457794}, {7147144, 18421769}, {7149049, 18417293}, {7159603, 18394029}, {7363683, 17954605}, {7788110, 17038301}, {4868477, 15550669}, {3351039, 14777491},  | ||||
| 		{3318305, 14760812}, {3708029, 14026016}, {3710747, 14020890}, {3719984, 14002484}, {8039120, 16203201}, {8077586, 16222801}, {8193537, 16281881}, {8645019, 15517733}, {8649067, 15510734}, {8668391, 15477321}, {8670973, 15473199},  | ||||
| 		{8685036, 15451871}, {8955346, 15049780}, {9517887, 14211149}, {6866919, 12285108}, {5489112, 11284075}, {5459391, 11262481}, {5959259, 10597695}, {5962745, 10593058}, {5974747, 10576324}, {9896454, 13425601}, {9931382, 13450977},  | ||||
| 		{10036663, 13527468}, {10602111, 12843352}, {10607203, 12837073}, {10631516, 12807093}, {10634711, 12803426}, {10651937, 12784561}, {10981820, 12429709}, {11668626, 11689407}, {8147345, 8168126}, {8121368, 8142148}, {8719089, 7563749}, | ||||
| 		{8723258, 7559715}, {8737731, 7545064}, {12165414, 10972746}, {12195941, 11003274}, {12287960, 11095293}, {12953467, 10508056}, {12959479, 10502650}, {12988183, 10476843}, {12991912, 10473721}, {13011878, 10457783}, {13393211, 10158903}, | ||||
| 		{14187378, 9535150}, {12261338, 6884179}, {11260306, 5506371}, {11238712, 5476650}, {11919550, 4998885}, {11924299, 4995552}, {11940886, 4983346}, {14790161, 8905032}, {14815537, 8939959}, {14892028, 9045240}, {15641210, 8569348},  | ||||
| 		{15647994, 8564950}, {15680381, 8543951}, {15684553, 8541450}, {15706766, 8528832}, {16130159, 8293285}, {17012123, 7801449}, {15524489, 4881814}, {14751314, 3364373}, {14734635, 3331640}, {15481841, 2966253}, {15487053, 2963704},  | ||||
| 		{15505344, 2954242}, {17706054, 7273386}, {17725654, 7311852}, {17784734, 7427803}, {18599135, 7074961}, {18606523, 7071678}, {18641796, 7056004}, {18646308, 7054187}, {18670222, 7045199}, {19125250, 6878787}, {20073289, 6530975},  | ||||
| 		{19060715, 3414573}, {18534440, 1794864}, {18523088, 1759924}, {19318247, 1515921}, {19323794, 1514219}, {19343340, 1507736}, {20841293, 6117964}, {20854634, 6159023}, {20894848, 6282789}, {21754417, 6061696}, {21762228, 6059609},  | ||||
| 		{21799518, 6049647}, {21804259, 6048557}, {21829284, 6043421}, {22304743, 5950237}, {23295525, 5755007}, {22782917, 2518572}, {22516497, 836476}, {22510750, 800190}, {23334299, 683591}, {23340043, 682777}, {23360363, 679431},  | ||||
| 		{24118676, 5467229}, {24125430, 5509869}, {24145787, 5638402}, {25029368, 5554507}, {25037409, 5553668}, {25075799, 5549661}, {25080652, 5549327}, {25106172, 5548168}, {25590355, 5530509}, {26599476, 5492671}, {26599476, 476096} | ||||
| 	}; | ||||
| 	return out; | ||||
| } | ||||
| 
 | ||||
| SCENARIO("Elephant foot compensation", "[ElephantFoot]") { | ||||
| 
 | ||||
| 	GIVEN("Large box") { | ||||
|  | @ -293,6 +362,21 @@ SCENARIO("Elephant foot compensation", "[ElephantFoot]") { | |||
| 		    SVG::export_expolygons(debug_out_path("elephant_foot_compensation_4.svg").c_str(),  | ||||
| 				{ { { expoly },             { "gray", "black", "blue", coord_t(scale_(0.02)), 0.5f, "black", coord_t(scale_(0.05)) } }, | ||||
| 				  { { expoly_compensated }, { "gray", "black", "blue", coord_t(scale_(0.02)), 0.5f, "black", coord_t(scale_(0.05)) } } }); | ||||
| #endif /* TESTS_EXPORT_SVGS */ | ||||
|             THEN("area of the compensated polygon is smaller") { | ||||
|                 REQUIRE(expoly_compensated.area() < expoly.area()); | ||||
|             } | ||||
|         } | ||||
| 	} | ||||
| 
 | ||||
| 	GIVEN("Vase with fins") { | ||||
| 		ExPolygon expoly = vase_with_fins(); | ||||
|         WHEN("Compensated") { | ||||
| 			ExPolygon expoly_compensated = elephant_foot_compensation(expoly, Flow(0.419999987f, 0.2f, 0.4f, false), 0.41f); | ||||
| #ifdef TESTS_EXPORT_SVGS | ||||
| 		    SVG::export_expolygons(debug_out_path("elephant_foot_compensation_vase_with_fins.svg").c_str(),  | ||||
| 				{ { { expoly },             { "gray", "black", "blue", coord_t(scale_(0.02)), 0.5f, "black", coord_t(scale_(0.05)) } }, | ||||
| 				  { { expoly_compensated }, { "gray", "black", "blue", coord_t(scale_(0.02)), 0.5f, "black", coord_t(scale_(0.05)) } } }); | ||||
| #endif /* TESTS_EXPORT_SVGS */ | ||||
|             THEN("area of the compensated polygon is smaller") { | ||||
|                 REQUIRE(expoly_compensated.area() < expoly.area()); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri