#include "LKH.h"
#include "Segment.h"

GainType Penalty_BWTSP(void)
{
    Node *N = &NodeSet[1], *NextN, *CurrentNode;
    int Forward = SUCC(N)->Id != N->Id + DimensionSaved;
    GainType Cost, P = 0;
    int WhiteCount;
    static Node *StartNode = 0;

    if (!StartNode)
        StartNode = N;
    if (StartNode->Id > DimensionSaved)
        StartNode -= DimensionSaved;
    N = StartNode;
    do {
        CurrentNode = N;
        NextN = Forward ? SUCC(N) : PREDD(N);
        if (NextN->Id > DimensionSaved)
            NextN = Forward ? SUCC(NextN) : PREDD(NextN);
        WhiteCount = 0;
        Cost = 0;
        while (NextN->Id > BWTSP_B) {
            WhiteCount++;
            Cost += C(N, NextN) - N->Pi - NextN->Pi;
            NextN = Forward ? SUCC(NextN) : PREDD(NextN);
            if (NextN->Id > DimensionSaved)
                NextN = Forward ? SUCC(NextN) : PREDD(NextN);
            N = NextN;
        }
        N = NextN;
        Cost /= Precision;
        if (Cost > BWTSP_L)
            P += Cost - BWTSP_L;
        if (WhiteCount > BWTSP_Q)
            P += WhiteCount - BWTSP_Q;
        if (P > CurrentPenalty ||
            (P == CurrentPenalty && CurrentGain <= 0)) {
            StartNode = CurrentNode;
            return CurrentPenalty + (CurrentGain > 0);
        }
    } while (N != StartNode);
    return P;
}
