Two new engine classes subclassing DefaultNestEngine that override CreateComparer, PreferredDirection, and BuildAngles to optimize for preserving side remnants. Both registered in NestEngineRegistry and covered by 6 integration tests. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
43 lines
1.5 KiB
C#
43 lines
1.5 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using OpenNest.Engine;
|
|
using OpenNest.Engine.Fill;
|
|
using OpenNest.Geometry;
|
|
using OpenNest.Math;
|
|
|
|
namespace OpenNest
|
|
{
|
|
/// <summary>
|
|
/// Optimizes for the largest top-side horizontal drop.
|
|
/// Scores by count first, then minimizes Y-extent.
|
|
/// Prefers vertical nest direction and angles that keep parts narrow in Y.
|
|
/// </summary>
|
|
public class HorizontalRemnantEngine : DefaultNestEngine
|
|
{
|
|
public HorizontalRemnantEngine(Plate plate) : base(plate) { }
|
|
|
|
public override string Name => "Horizontal Remnant";
|
|
|
|
public override string Description => "Optimizes for largest top-side horizontal drop";
|
|
|
|
protected override IFillComparer CreateComparer() => new HorizontalRemnantComparer();
|
|
|
|
public override NestDirection? PreferredDirection => NestDirection.Vertical;
|
|
|
|
public override List<double> BuildAngles(NestItem item, double bestRotation, Box workArea)
|
|
{
|
|
var baseAngles = new List<double> { bestRotation, bestRotation + Angle.HalfPI };
|
|
baseAngles.Sort((a, b) => RotatedHeight(item, a).CompareTo(RotatedHeight(item, b)));
|
|
return baseAngles;
|
|
}
|
|
|
|
private static double RotatedHeight(NestItem item, double angle)
|
|
{
|
|
var bb = item.Drawing.Program.BoundingBox();
|
|
var cos = System.Math.Abs(System.Math.Cos(angle));
|
|
var sin = System.Math.Abs(System.Math.Sin(angle));
|
|
return bb.Length * cos + bb.Width * sin;
|
|
}
|
|
}
|
|
}
|