KiCad PCB EDA Suite
Loading...
Searching...
No Matches
pns_walkaround.h
Go to the documentation of this file.
1/*
2 * KiRouter - a push-and-(sometimes-)shove PCB router
3 *
4 * Copyright (C) 2013-2014 CERN
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 * Author: Tomasz Wlostowski <[email protected]>
7 *
8 * This program is free software: you can redistribute it and/or modify it
9 * under the terms of the GNU General Public License as published by the
10 * Free Software Foundation, either version 3 of the License, or (at your
11 * option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License along
19 * with this program. If not, see <http://www.gnu.org/licenses/>.
20 */
21
22#ifndef __PNS_WALKAROUND_H
23#define __PNS_WALKAROUND_H
24
25#include <set>
26
27#include "pns_line.h"
28#include "pns_node.h"
29#include "pns_router.h"
30#include "pns_logger.h"
31#include "pns_algo_base.h"
32#include "pns_topology.h"
33
34namespace PNS {
35
36class WALKAROUND : public ALGO_BASE
37{
38 static constexpr int MaxWalkPolicies = 3;
39
40public:
41 WALKAROUND( NODE* aWorld, ROUTER* aRouter ) :
42 ALGO_BASE ( aRouter ),
43 m_world( aWorld )
44 {
45 m_forceWinding = false;
47
48 // Initialize other members, to avoid uninitialized variables.
49 m_iteration = 0;
50 m_initialLength = 0.0;
51 m_forceCw = false;
52 m_forceLongerPath = false;
53 m_lengthLimitOn = true;
54 m_useShortestPath = false;
57 }
58
60
61 enum STATUS
62 {
68 };
69
71 {
72 WP_CW = 0,
73 WP_CCW = 1,
74 WP_SHORTEST = 2
75 };
76
77 struct RESULT
78 {
80 {
81 for( int i = 0; i < MaxWalkPolicies; i++ )
82 status [i] = ST_NONE;
83 }
84
87 };
88
89 void SetWorld( NODE* aNode )
90 {
91 m_world = aNode;
92 }
93
94 void SetIterationLimit( const int aIterLimit )
95 {
96 m_iterationLimit = aIterLimit;
97 }
98
99 void SetSolidsOnly( bool aSolidsOnly )
100 {
101 if( aSolidsOnly )
103 else
105 }
106
107 void SetItemMask( int aMask )
108 {
109 m_itemMask = aMask;
110 }
111
112 void SetForceWinding ( bool aEnabled, bool aCw )
113 {
114 m_forceCw = aCw;
115 m_forceWinding = aEnabled;
116 }
117
118 void SetPickShortestPath( bool aEnabled )
119 {
120 m_useShortestPath = aEnabled;
121 }
122
123 void RestrictToCluster( bool aEnabled, const TOPOLOGY::CLUSTER& aCluster );
124
125 STATUS Route( const LINE& aInitialPath, LINE& aWalkPath,
126 bool aOptimize = true );
127
128 const RESULT Route( const LINE& aInitialPath );
129
130 void SetLengthLimit( bool aEnable, double aLengthExpansionFactor )
131 {
132 m_lengthLimitOn = aEnable;
133 m_lengthExpansionFactor = aLengthExpansionFactor;
134 }
135
136 void SetAllowedPolicies( std::vector<WALK_POLICY> aPolicies);
137
138private:
139 void start( const LINE& aInitialPath );
140 bool singleStep();
141
144
152 std::set<const ITEM*> m_restrictedSet;
153 std::vector<VECTOR2I> m_restrictedVertices;
161 std::optional<TOPOLOGY::CLUSTER> m_lastShortestCluster;
164};
165
166}
167
168#endif // __PNS_WALKAROUND_H
Base class for all P&S algorithms (shoving, walkaround, line placement, dragging, etc....
Definition: pns_algo_base.h:43
ROUTING_SETTINGS & Settings() const
Return the logger object, allowing to dump geometry to a file.
Represents a track on a PCB, connecting two non-trivial joints (that is, vias, pads,...
Definition: pns_line.h:62
Keep the router "world" - i.e.
Definition: pns_node.h:231
std::optional< OBSTACLE > OPT_OBSTACLE
Definition: pns_node.h:241
void SetIterationLimit(const int aIterLimit)
void SetLengthLimit(bool aEnable, double aLengthExpansionFactor)
void RestrictToCluster(bool aEnabled, const TOPOLOGY::CLUSTER &aCluster)
void SetSolidsOnly(bool aSolidsOnly)
STATUS Route(const LINE &aInitialPath, LINE &aWalkPath, bool aOptimize=true)
void SetForceWinding(bool aEnabled, bool aCw)
void SetWorld(NODE *aNode)
bool m_enabledPolicies[MaxWalkPolicies]
NODE::OPT_OBSTACLE nearestObstacle(const LINE &aPath)
void SetItemMask(int aMask)
std::vector< VECTOR2I > m_restrictedVertices
NODE::OPT_OBSTACLE m_currentObstacle[MaxWalkPolicies]
void SetAllowedPolicies(std::vector< WALK_POLICY > aPolicies)
void SetPickShortestPath(bool aEnabled)
VECTOR2I m_cursorPos
void start(const LINE &aInitialPath)
TOPOLOGY::CLUSTER m_currentCluster[MaxWalkPolicies]
static constexpr int MaxWalkPolicies
std::optional< TOPOLOGY::CLUSTER > m_lastShortestCluster
WALKAROUND(NODE *aWorld, ROUTER *aRouter)
double m_lengthExpansionFactor
std::set< const ITEM * > m_restrictedSet
Push and Shove diff pair dimensions (gap) settings dialog.
LINE lines[MaxWalkPolicies]
STATUS status[MaxWalkPolicies]