KiCad PCB EDA Suite
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
PATH_OPTIMISATIONS Struct Reference

Struct to control which optimisations the length calculation code runs on the given path objects. More...

#include <length_calculation.h>

Public Attributes

bool OptimiseViaLayers = false
 Optimise via layers for height calculations, ensuring only the distance between routed segments is considered.
 
bool MergeTracks = false
 Merges all contiguous (end-to-end, same layer) tracks.
 
bool OptimiseTracesInPads = false
 Optimises the electrical length of tracks within pads.
 
bool InferViaInPad = false
 Determines if there is a via-in-pad present on the board but not in the item set.
 

Detailed Description

Struct to control which optimisations the length calculation code runs on the given path objects.

This is required as some call sites (e.g. PNS) run their own path optimisation, whereas others (e.g. Net Inspector) do not.

Definition at line 167 of file length_calculation.h.

Member Data Documentation

◆ InferViaInPad

bool PATH_OPTIMISATIONS::InferViaInPad = false

Determines if there is a via-in-pad present on the board but not in the item set.

This condition can arise from the PNS meander placer. TODO (JJ): This can be fixed in the router

Definition at line 185 of file length_calculation.h.

Referenced by LENGTH_CALCULATION::CalculateLengthDetails().

◆ MergeTracks

bool PATH_OPTIMISATIONS::MergeTracks = false

Merges all contiguous (end-to-end, same layer) tracks.

Definition at line 174 of file length_calculation.h.

Referenced by LENGTH_CALCULATION::CalculateLengthDetails().

◆ OptimiseTracesInPads

bool PATH_OPTIMISATIONS::OptimiseTracesInPads = false

Optimises the electrical length of tracks within pads.

Note that the track must terminate at the trace anchor point to be considered for optimisation. Will require MergeTracks if used with a non-contiguous item set.

Definition at line 180 of file length_calculation.h.

Referenced by LENGTH_CALCULATION::CalculateLengthDetails().

◆ OptimiseViaLayers

bool PATH_OPTIMISATIONS::OptimiseViaLayers = false

Optimise via layers for height calculations, ensuring only the distance between routed segments is considered.

Definition at line 171 of file length_calculation.h.

Referenced by LENGTH_CALCULATION::CalculateLengthDetails(), PNS_KICAD_IFACE_BASE::CalculateRoutedPathLength(), PNS_VIEWER_IFACE::CalculateRoutedPathLength(), BOARD::GetTrackLength(), and DRC_TEST_PROVIDER_MATCHED_LENGTH::runInternal().


The documentation for this struct was generated from the following file: