feat: add directional part sequencers (RightSide, LeftSide, BottomSide)
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
17
OpenNest.Engine/Sequencing/BottomSideSequencer.cs
Normal file
17
OpenNest.Engine/Sequencing/BottomSideSequencer.cs
Normal file
@@ -0,0 +1,17 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
namespace OpenNest.Engine.Sequencing
|
||||
{
|
||||
public class BottomSideSequencer : IPartSequencer
|
||||
{
|
||||
public List<SequencedPart> Sequence(IReadOnlyList<Part> parts, Plate plate)
|
||||
{
|
||||
return parts
|
||||
.OrderBy(p => p.Location.Y)
|
||||
.ThenBy(p => p.Location.X)
|
||||
.Select(p => new SequencedPart { Part = p })
|
||||
.ToList();
|
||||
}
|
||||
}
|
||||
}
|
||||
17
OpenNest.Engine/Sequencing/LeftSideSequencer.cs
Normal file
17
OpenNest.Engine/Sequencing/LeftSideSequencer.cs
Normal file
@@ -0,0 +1,17 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
namespace OpenNest.Engine.Sequencing
|
||||
{
|
||||
public class LeftSideSequencer : IPartSequencer
|
||||
{
|
||||
public List<SequencedPart> Sequence(IReadOnlyList<Part> parts, Plate plate)
|
||||
{
|
||||
return parts
|
||||
.OrderBy(p => p.Location.X)
|
||||
.ThenBy(p => p.Location.Y)
|
||||
.Select(p => new SequencedPart { Part = p })
|
||||
.ToList();
|
||||
}
|
||||
}
|
||||
}
|
||||
17
OpenNest.Engine/Sequencing/RightSideSequencer.cs
Normal file
17
OpenNest.Engine/Sequencing/RightSideSequencer.cs
Normal file
@@ -0,0 +1,17 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
namespace OpenNest.Engine.Sequencing
|
||||
{
|
||||
public class RightSideSequencer : IPartSequencer
|
||||
{
|
||||
public List<SequencedPart> Sequence(IReadOnlyList<Part> parts, Plate plate)
|
||||
{
|
||||
return parts
|
||||
.OrderByDescending(p => p.Location.X)
|
||||
.ThenBy(p => p.Location.Y)
|
||||
.Select(p => new SequencedPart { Part = p })
|
||||
.ToList();
|
||||
}
|
||||
}
|
||||
}
|
||||
75
OpenNest.Tests/Sequencing/DirectionalSequencerTests.cs
Normal file
75
OpenNest.Tests/Sequencing/DirectionalSequencerTests.cs
Normal file
@@ -0,0 +1,75 @@
|
||||
using System.Collections.Generic;
|
||||
using OpenNest.CNC;
|
||||
using OpenNest.Engine.Sequencing;
|
||||
using OpenNest.Geometry;
|
||||
using Xunit;
|
||||
|
||||
namespace OpenNest.Tests.Sequencing;
|
||||
|
||||
public class DirectionalSequencerTests
|
||||
{
|
||||
private static Part MakePartAt(double x, double y) => TestHelpers.MakePartAt(x, y);
|
||||
private static Plate MakePlate(params Part[] parts) => TestHelpers.MakePlate(60, 120, parts);
|
||||
|
||||
[Fact]
|
||||
public void RightSide_SortsXDescending()
|
||||
{
|
||||
var a = MakePartAt(10, 5);
|
||||
var b = MakePartAt(30, 5);
|
||||
var c = MakePartAt(20, 5);
|
||||
var plate = MakePlate(a, b, c);
|
||||
|
||||
var sequencer = new RightSideSequencer();
|
||||
var result = sequencer.Sequence(plate.Parts.ToList(), plate);
|
||||
|
||||
Assert.Same(b, result[0].Part);
|
||||
Assert.Same(c, result[1].Part);
|
||||
Assert.Same(a, result[2].Part);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void LeftSide_SortsXAscending()
|
||||
{
|
||||
var a = MakePartAt(10, 5);
|
||||
var b = MakePartAt(30, 5);
|
||||
var c = MakePartAt(20, 5);
|
||||
var plate = MakePlate(a, b, c);
|
||||
|
||||
var sequencer = new LeftSideSequencer();
|
||||
var result = sequencer.Sequence(plate.Parts.ToList(), plate);
|
||||
|
||||
Assert.Same(a, result[0].Part);
|
||||
Assert.Same(c, result[1].Part);
|
||||
Assert.Same(b, result[2].Part);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void BottomSide_SortsYAscending()
|
||||
{
|
||||
var a = MakePartAt(5, 20);
|
||||
var b = MakePartAt(5, 5);
|
||||
var c = MakePartAt(5, 10);
|
||||
var plate = MakePlate(a, b, c);
|
||||
|
||||
var sequencer = new BottomSideSequencer();
|
||||
var result = sequencer.Sequence(plate.Parts.ToList(), plate);
|
||||
|
||||
Assert.Same(b, result[0].Part);
|
||||
Assert.Same(c, result[1].Part);
|
||||
Assert.Same(a, result[2].Part);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void RightSide_TiesBrokenByPerpendicularAxis()
|
||||
{
|
||||
var a = MakePartAt(10, 20);
|
||||
var b = MakePartAt(10, 5);
|
||||
var plate = MakePlate(a, b);
|
||||
|
||||
var sequencer = new RightSideSequencer();
|
||||
var result = sequencer.Sequence(plate.Parts.ToList(), plate);
|
||||
|
||||
Assert.Same(b, result[0].Part);
|
||||
Assert.Same(a, result[1].Part);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user