mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	Simplify creation of $n, @x and @y in point_in_polygon test.
Gives 30% speed up on simcop2387's coaster on my laptop and it cuts the maximum resident set size too. I know this is going to be replaced but thought this might be useful in the meantime.
This commit is contained in:
		
							parent
							
								
									4d2a813450
								
							
						
					
					
						commit
						2ef565fc4d
					
				
					 1 changed files with 7 additions and 6 deletions
				
			
		|  | @ -154,15 +154,16 @@ sub point_in_polygon { | ||||||
|     my ($point, $polygon) = @_; |     my ($point, $polygon) = @_; | ||||||
|      |      | ||||||
|     my ($x, $y) = @$point; |     my ($x, $y) = @$point; | ||||||
|     my @xy = map @$_, @$polygon; |     my $n = @$polygon; | ||||||
|  |     my @x; | ||||||
|  |     my @y; | ||||||
|  |     foreach (0..$n-1) { | ||||||
|  |       push @x, $polygon->[$_]->[X]; | ||||||
|  |       push @y, $polygon->[$_]->[Y]; | ||||||
|  |     } | ||||||
|      |      | ||||||
|     # Derived from the comp.graphics.algorithms FAQ, |     # Derived from the comp.graphics.algorithms FAQ, | ||||||
|     # courtesy of Wm. Randolph Franklin |     # courtesy of Wm. Randolph Franklin | ||||||
|     my $n = @xy / 2;                        # Number of points in polygon |  | ||||||
|     my @i = map { 2*$_ } 0..(@xy/2);        # The even indices of @xy |  | ||||||
|     my @x = map { $xy[$_]     } @i;         # Even indices: x-coordinates |  | ||||||
|     my @y = map { $xy[$_ + 1] } @i;         # Odd indices:  y-coordinates |  | ||||||
|      |  | ||||||
|     my ($i, $j); |     my ($i, $j); | ||||||
|     my $side = 0;                           # 0 = outside; 1 = inside |     my $side = 0;                           # 0 = outside; 1 = inside | ||||||
|     for ($i = 0, $j = $n - 1; $i < $n; $j = $i++) { |     for ($i = 0, $j = $n - 1; $i < $n; $j = $i++) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Mark Hindess
						Mark Hindess