KiCad PCB EDA Suite
Loading...
Searching...
No Matches
tuning_profile_parameters_user_defined.h
Go to the documentation of this file.
1/*
2* This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, you may find one here:
18 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
19 * or you may search the http://www.gnu.org website for the version 2 license,
20 * or you may write to the Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
22 */
23
24#ifndef PCB_NEW_TUNING_PROFILE_PARAMETERS_USER_DEFINED_H
25#define PCB_NEW_TUNING_PROFILE_PARAMETERS_USER_DEFINED_H
26
27
30
32{
33public:
35 TUNING_PROFILE_PARAMETERS_IFACE( aBoard, aCalculation )
36 {
37 }
38
43 void OnSettingsChanged() override;
44
52 std::vector<int64_t> GetPropagationDelays( const std::vector<LENGTH_DELAY_CALCULATION_ITEM>& aItems,
53 const TUNING_PROFILE_GEOMETRY_CONTEXT& aContext ) override;
54
62 const TUNING_PROFILE_GEOMETRY_CONTEXT& aContext ) override;
63
73 int64_t GetViaPropagationDelay( const PCB_LAYER_ID aSignalStartLayer, const PCB_LAYER_ID aSignalEndLayer,
74 const PCB_LAYER_ID aViaStartLayer, const PCB_LAYER_ID aViaEndLayer,
75 const TUNING_PROFILE_GEOMETRY_CONTEXT& aContext ) const override;
76
84 int64_t GetTrackLengthForPropagationDelay( int64_t aDelay,
85 const TUNING_PROFILE_GEOMETRY_CONTEXT& aContext ) override;
86
94 const TUNING_PROFILE_GEOMETRY_CONTEXT& aContext ) override;
95
96private:
97 void rebuildCaches();
98
101 {
106
107 bool operator<( const VIA_OVERRIDE_CACHE_KEY& aOther ) const
108 {
109 if( SignalStart < aOther.SignalStart )
110 return true;
111 if( aOther.SignalStart < SignalStart )
112 return false;
113 if( SignalEnd < aOther.SignalEnd )
114 return true;
115 if( aOther.SignalEnd < SignalEnd )
116 return false;
117 if( ViaStart < aOther.ViaStart )
118 return true;
119 if( aOther.ViaStart < ViaStart )
120 return false;
121 return ViaEnd < aOther.ViaEnd;
122 }
123 };
124
138 const TUNING_PROFILE_GEOMETRY_CONTEXT& aContext,
139 const TUNING_PROFILE* aDelayProfile ) const;
140
150 int64_t getViaPropagationDelay( const PCB_LAYER_ID aSignalStartLayer, const PCB_LAYER_ID aSignalEndLayer,
151 const PCB_LAYER_ID aViaStartLayer, const PCB_LAYER_ID aViaEndLayer,
152 const TUNING_PROFILE* aTuningProfile ) const;
153
160 const TUNING_PROFILE* GetTuningProfile( const wxString& aDelayProfileName ) const;
161
163 std::map<wxString, const TUNING_PROFILE*> m_delayProfilesCache;
164
166 std::map<wxString, std::map<VIA_OVERRIDE_CACHE_KEY, int64_t>> m_viaOverridesCache;
167};
168
169#endif //PCB_NEW_TUNING_PROFILE_PARAMETERS_USER_DEFINED_H
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:323
Lightweight class which holds a pad, via, or a routed trace outline.
Class which calculates lengths (and associated routing statistics) in a BOARD context.
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
TUNING_PROFILE_PARAMETERS_IFACE(BOARD *aBoard, LENGTH_DELAY_CALCULATION *aCalculation)
std::map< wxString, const TUNING_PROFILE * > m_delayProfilesCache
Cached map of tuning profile names to per-layer time domain parameters.
int64_t GetTrackLengthForPropagationDelay(int64_t aDelay, const TUNING_PROFILE_GEOMETRY_CONTEXT &aContext) override
Gets the track length (in internal distance units) required for the given propagation delay (in inter...
int64_t getViaPropagationDelay(const PCB_LAYER_ID aSignalStartLayer, const PCB_LAYER_ID aSignalEndLayer, const PCB_LAYER_ID aViaStartLayer, const PCB_LAYER_ID aViaEndLayer, const TUNING_PROFILE *aTuningProfile) const
Gets the via propagation delay for the given via layer geometry.
int64_t CalculatePropagationDelayForShapeLineChain(const SHAPE_LINE_CHAIN &aShape, const TUNING_PROFILE_GEOMETRY_CONTEXT &aContext) override
Gets the propagation delay for the given shape line chain.
std::map< wxString, std::map< VIA_OVERRIDE_CACHE_KEY, int64_t > > m_viaOverridesCache
Cached per-tuning profile via overrides.
int64_t GetPropagationDelay(const LENGTH_DELAY_CALCULATION_ITEM &aItem, const TUNING_PROFILE_GEOMETRY_CONTEXT &aContext) override
Gets the propagation delay (in internal units) for the given item in the given geometry context.
const TUNING_PROFILE * GetTuningProfile(const wxString &aDelayProfileName) const
Gets the tuning profile pointer for the given tuning profile name.
void OnSettingsChanged() override
Event called by the length and time calculation architecture if netclass definitions have changed.
std::vector< int64_t > GetPropagationDelays(const std::vector< LENGTH_DELAY_CALCULATION_ITEM > &aItems, const TUNING_PROFILE_GEOMETRY_CONTEXT &aContext) override
Gets the propagation delays (in internal units) for the given items in the given geometry context.
int64_t getPropagationDelay(const LENGTH_DELAY_CALCULATION_ITEM &aItem, const TUNING_PROFILE_GEOMETRY_CONTEXT &aContext, const TUNING_PROFILE *aDelayProfile) const
Gets the propagation delay (in internal units) for the given item in the given geometry context,...
TUNING_PROFILE_PARAMETERS_USER_DEFINED(BOARD *aBoard, LENGTH_DELAY_CALCULATION *aCalculation)
int64_t GetViaPropagationDelay(const PCB_LAYER_ID aSignalStartLayer, const PCB_LAYER_ID aSignalEndLayer, const PCB_LAYER_ID aViaStartLayer, const PCB_LAYER_ID aViaEndLayer, const TUNING_PROFILE_GEOMETRY_CONTEXT &aContext) const override
Gets the via propagation delay for the given via layer geometry.
PCB_LAYER_ID
A quick note on layer IDs:
Definition layer_ids.h:60
A data structure to contain basic geometry data which can affect signal propagation calculations.
Represents a single line in the tuning profile configuration grid.