70 lines
2.1 KiB
C#
70 lines
2.1 KiB
C#
using System.Collections.Generic;
|
|
using OpenNest.CNC;
|
|
using OpenNest.CNC.CuttingStrategy;
|
|
using OpenNest.Engine.Sequencing;
|
|
using OpenNest.Geometry;
|
|
using Xunit;
|
|
|
|
namespace OpenNest.Tests.Sequencing;
|
|
|
|
public class AdvancedSequencerTests
|
|
{
|
|
private static Part MakePartAt(double x, double y) => TestHelpers.MakePartAt(x, y);
|
|
|
|
[Fact]
|
|
public void GroupsIntoRows_NoAlternate()
|
|
{
|
|
var plate = new Plate(100, 100);
|
|
var row1a = MakePartAt(10, 10);
|
|
var row1b = MakePartAt(30, 10);
|
|
var row2a = MakePartAt(10, 50);
|
|
var row2b = MakePartAt(30, 50);
|
|
plate.Parts.Add(row1a);
|
|
plate.Parts.Add(row1b);
|
|
plate.Parts.Add(row2a);
|
|
plate.Parts.Add(row2b);
|
|
|
|
var parameters = new SequenceParameters
|
|
{
|
|
Method = SequenceMethod.Advanced,
|
|
MinDistanceBetweenRowsColumns = 5.0,
|
|
AlternateRowsColumns = false
|
|
};
|
|
var sequencer = new AdvancedSequencer(parameters);
|
|
var result = sequencer.Sequence(plate.Parts.ToList(), plate);
|
|
|
|
Assert.Same(row1a, result[0].Part);
|
|
Assert.Same(row1b, result[1].Part);
|
|
Assert.Same(row2a, result[2].Part);
|
|
Assert.Same(row2b, result[3].Part);
|
|
}
|
|
|
|
[Fact]
|
|
public void SerpentineAlternatesDirection()
|
|
{
|
|
var plate = new Plate(100, 100);
|
|
var r1Left = MakePartAt(10, 10);
|
|
var r1Right = MakePartAt(30, 10);
|
|
var r2Left = MakePartAt(10, 50);
|
|
var r2Right = MakePartAt(30, 50);
|
|
plate.Parts.Add(r1Left);
|
|
plate.Parts.Add(r1Right);
|
|
plate.Parts.Add(r2Left);
|
|
plate.Parts.Add(r2Right);
|
|
|
|
var parameters = new SequenceParameters
|
|
{
|
|
Method = SequenceMethod.Advanced,
|
|
MinDistanceBetweenRowsColumns = 5.0,
|
|
AlternateRowsColumns = true
|
|
};
|
|
var sequencer = new AdvancedSequencer(parameters);
|
|
var result = sequencer.Sequence(plate.Parts.ToList(), plate);
|
|
|
|
Assert.Same(r1Left, result[0].Part);
|
|
Assert.Same(r1Right, result[1].Part);
|
|
Assert.Same(r2Right, result[2].Part);
|
|
Assert.Same(r2Left, result[3].Part);
|
|
}
|
|
}
|