AMF-Placer  2.0
An Open-Source Timing-driven Analytical Mixed-size FPGA Placer
Class Hierarchy

Go to the graphical class hierarchy

This inheritance list is sorted roughly, but not completely, alphabetically:
[detail level 12]
 CWirelengthOptimizer::_CellWithScore
 CIncrementalBELPacker::_CellWithScore
 CPlacementInfo::_ClockNetCoverageRetangular clock region coverage of a clock net
 CPlacementInfo::PlacementMacro::_fixedPlacementInfo_inMacroSome constaints of elements' relative locations are defined by the design. We need to record this
 CPlacementInfo::PlacementNet::_pinOffset
 CWirelengthOptimizer::_PUWithScore
 CIncrementalBELPacker::_PUWithScore
 CParallelCLBPacker::_PUWithScoreHelper struct for candidate site sorting
 CParallelCLBPacker::_siteWithScoreHelper struct for candidate site sorting
 CWirelengthOptimizer::_slackEnhanceTuple
 CAMFPlacerAMFPlacer is an analytical mixed-size FPGA placer
 Carray
 CIncrementalBELPacker::FFLocationFFLocation records the FF cell pointer and the location of the FF cell for kdt::KDTree construction which can help to find neighbors for cells
 CParallelCLBPacker::PULocationPULocation is a helper class to find the neighbor PlacementUnits with KD-Tree
 CPlacementInfo::CellBinInfoRecord the bin information for a cell (BELtype, column/row, resource demand)
 CCLBLegalizerCLBLegalizer maps CLBs (each of which consists of one site) to legal location. e.g. LUTRAM, except those CLBs in CARRY8_Chain
 CDeviceInfo::ClockColumnColumn of site in clock region
 CDeviceInfo::ClockRegionClass for clock regions on FPGA
 CPlacementInfo::ClusterNetThe net between the objects of ClusterUnit class
 CClusterPlacerClusterPlacer will cluster nodes in the given netlist and place the clusters on the device based on simulated-annealing as initial placement
 CPlacementInfo::ClusterUnitGroup of PlacementUnits
 CPlacementInfo::CompatiblePlacementTableDescribes the type mapping from design to device, where a cell can be placed (which BEL in which site)
 CDesignInfo::ControlSetInfoA control set is a combination of CLK, CE and SR signal. It could be nullptr (not related to control set)
 CDesignInfo::DesignElementBasic class of element in a design
 CDesignInfo::DesignCellDesignCell in design netlist, DesignPin objects of which might connect to DesignNet objects
 CDesignInfo::DesignNetDesign net (hyperedge) defined in the design, connecting to pins of cells
 CDesignInfo::DesignPinA design pin on a design cell connected to a net
 CDesignInfoInformation related to FPGA designs, including design cells and their interconnections
 CDeviceInfo::DeviceElementBasic class of device element
 CDeviceInfo::DeviceBELBEL(Basic Element of Logic), the smallest undividable element
 CDeviceInfo::DeviceSiteSite class for site on device
 CDeviceInfo::DeviceTileA tile is a combination of sites
 CDeviceInfoInformation class related to FPGA device, including the details of BEL/Site/Tile/ClockRegion
 CDeviceInfo::DeviceSite::DeviceSitePinInfosClass record the pin on the site boundary
 CGeneralSpreader::SpreadRegion::expandOpStruct to describe the expanding operation for the SpreadRegion
 CExternalProcessFuncExternalProcessFunc is a wrapper of an external exectable for multi-process scenario with shared memory
 CGeneralSpreaderGeneralSpreader accounts for the cell spreading, which controls the cell density of specific resource type, under the device constraints for specific regions
 CGlobalPlacerGlobalPlacer accounts for the general iterations in global placement
 CGraphPartitioner< NodeList, NetList >GraphPartitioner will recursively bi-partition the netlist (which could be netlist of clusters) based on connectivitity and the net weights
 CGraphPartitioner< std::vector< PlacementInfo::ClusterUnit * >, std::vector< PlacementInfo::ClusterNet * > >
 CGraphPartitioner< std::vector< PlacementInfo::PlacementUnit * >, std::vector< PlacementInfo::PlacementNet * > >
 CIncrementalBELPackerIncrementalBELPacker incrementally packs some LUTs/FFs during global placement based on their distance, interconnection density and compatibility
 CInitialPackerInitialPacker will identify macros from the design netlist based on pattern matching
 CPlacementInfo::Location
 CPlacementInfo::PlacementSiteTypeInfo::location
 CMacroLegalizerMacroLegalizer maps DSP/BRAM/CARRY macros to legal location
 CMinCostBipartiteMatcher
 Cobject
 CexportDeviceLocation.siteInfo
 CVivadoGraphUtil.VivadoCell
 CVivadoGraphUtil.VivadoCoreCluster
 CVivadoGraphUtil.VivadoNet
 CVivadoGraphUtil.VivadoPatternCluster
 CVivadoGraphUtil.VivadoPatternClusterSeq
 CVivadoGraphUtil.VivadoPin
 CInitialPacker::PackedControlSetControl set information container used during initial packing
 CParallelCLBPacker::PackedControlSetPackedControlSet stores the data of a combination of FFs within one control set (clock enable/preset-reset/clock) that can be packed in a site
 CPacking_Netcompare
 CPacking_PUcompareUtility struct for the comparison between PlacementInfo::PlacementUnit according to PU ID
 CParallelCLBPacker::PackingCLBSite::PackingCLBClusterPackingCLBCluster is a container of cells/PlacementUnits which can be packed in the corresponding CLB site
 CParallelCLBPacker::PackingCLBSitePackingCLBSite is a container for the packing information (parameters, candidates and packing status) of a specific DeviceInfo::DeviceSite
 CParallelCLBPackerParallelCLBPacker will finally pack LUT/FF/MUX/CARRY elements into legal CLB sites in a parallel approach
 CPlacementInfo::PlacementBinInfoBEL bin for global placement for a specific shared BEL type
 CPlacementInfo::PlacementHybridBinInfoBEL bin for global placement for multiple specific shared BEL types
 CPlacementInfoInformation related to FPGA placement (wirelength optimization, cell spreading, legalization, packing)
 CPlacementInfo::PlacementNetPlacement net, compared to design net, includes information related to placement
 CPlacementInfo::PlacementSiteBinInfoSite bin for global placement for some specific Site types
 CPlacementInfo::PlacementSiteTypeInfoInformation for a site, e.g. what BEL in site and where are these kind of sites
 CPlacementTimingInfoPlacementTimingInfo is the container which record the timing information related to placement
 CPlacementTimingOptimizer
 CPlacementInfo::PlacementUnitMovement unit in placement with information of location and resource demand
 CPlacementInfo::PlacementMacroFixed group of multiple standard cells with constraints of their relative locations
 CPlacementInfo::PlacementUnpackedCellSmallest, indivisible, representable component. It will include only one standard cell
 CProcessFuncInterface
 CQPSolverWrapper
 CSAPlacer
 CParallelCLBPacker::PackingCLBSite::SiteBELMappingSiteBELMapping is a contain recording the mapping between cells and BELs
 CInitialPacker::SiteBELMappingSiteBELMapping is a contain recording the mapping between cells and BELs
 CQPSolverWrapper::solverDataType
 CQPSolverWrapper::solverSettingsType
 CGeneralSpreader::SpreadRegionSpreadRegion is an object that record cell spreading region information, including boundaries, cells, bins, and spreading boxes
 Cstreambuf
 CFILEbuf
 CGeneralSpreader::SpreadRegion::SubBoxSubBox is the exact container which is the object for bi-partitioning-based cell spreading
 CPlacementTimingInfo::TimingGraph< nodeType >::TimingEdgeTimingEdge records a directed interconnection relationship between two TimingNode. It is a point-to-point information instead of HyperEdge
 CPlacementTimingInfo::TimingGraph< nodeType >Directed graph for timing analysis
 CPlacementTimingInfo::TimingGraph< DesignInfo::DesignCell >
 CPlacementTimingInfo::TimingGraph< nodeType >::TimingNodeTimingNode is the node in TimingGraph, which could be pin or cell in the design netlist
 CWirelengthOptimizerWirelengthOptimizer builds numerical models based on the element locations and calls solvers to find an optimal solution of the placement