AMF-Placer  2.0
An Open-Source Timing-driven Analytical Mixed-size FPGA Placer
Class List
Here are the classes, structs, unions and interfaces with brief descriptions:
[detail level 123]
 NexportDeviceLocation
 CsiteInfo
 NVivadoGraphUtil
 CVivadoCell
 CVivadoCoreCluster
 CVivadoNet
 CVivadoPatternCluster
 CVivadoPatternClusterSeq
 CVivadoPin
 CAMFPlacerAMFPlacer is an analytical mixed-size FPGA placer
 CCLBLegalizerCLBLegalizer maps CLBs (each of which consists of one site) to legal location. e.g. LUTRAM, except those CLBs in CARRY8_Chain
 CClusterPlacerClusterPlacer will cluster nodes in the given netlist and place the clusters on the device based on simulated-annealing as initial placement
 CDesignInfoInformation related to FPGA designs, including design cells and their interconnections
 CControlSetInfoA control set is a combination of CLK, CE and SR signal. It could be nullptr (not related to control set)
 CDesignCellDesignCell in design netlist, DesignPin objects of which might connect to DesignNet objects
 CDesignElementBasic class of element in a design
 CDesignNetDesign net (hyperedge) defined in the design, connecting to pins of cells
 CDesignPinA design pin on a design cell connected to a net
 CDeviceInfoInformation class related to FPGA device, including the details of BEL/Site/Tile/ClockRegion
 CClockColumnColumn of site in clock region
 CClockRegionClass for clock regions on FPGA
 CDeviceBELBEL(Basic Element of Logic), the smallest undividable element
 CDeviceElementBasic class of device element
 CDeviceSiteSite class for site on device
 CDeviceSitePinInfosClass record the pin on the site boundary
 CDeviceTileA tile is a combination of sites
 CExternalProcessFuncExternalProcessFunc is a wrapper of an external exectable for multi-process scenario with shared memory
 CFILEbuf
 CGeneralSpreaderGeneralSpreader accounts for the cell spreading, which controls the cell density of specific resource type, under the device constraints for specific regions
 CSpreadRegionSpreadRegion is an object that record cell spreading region information, including boundaries, cells, bins, and spreading boxes
 CexpandOpStruct to describe the expanding operation for the SpreadRegion
 CSubBoxSubBox is the exact container which is the object for bi-partitioning-based cell spreading
 CGlobalPlacerGlobalPlacer accounts for the general iterations in global placement
 CGraphPartitionerGraphPartitioner will recursively bi-partition the netlist (which could be netlist of clusters) based on connectivitity and the net weights
 CIncrementalBELPackerIncrementalBELPacker incrementally packs some LUTs/FFs during global placement based on their distance, interconnection density and compatibility
 C_CellWithScore
 C_PUWithScore
 CFFLocationFFLocation records the FF cell pointer and the location of the FF cell for kdt::KDTree construction which can help to find neighbors for cells
 CInitialPackerInitialPacker will identify macros from the design netlist based on pattern matching
 CPackedControlSetControl set information container used during initial packing
 CSiteBELMappingSiteBELMapping is a contain recording the mapping between cells and BELs
 CMacroLegalizerMacroLegalizer maps DSP/BRAM/CARRY macros to legal location
 CMinCostBipartiteMatcher
 CPacking_Netcompare
 CPacking_PUcompareUtility struct for the comparison between PlacementInfo::PlacementUnit according to PU ID
 CParallelCLBPackerParallelCLBPacker will finally pack LUT/FF/MUX/CARRY elements into legal CLB sites in a parallel approach
 C_PUWithScoreHelper struct for candidate site sorting
 C_siteWithScoreHelper struct for candidate site sorting
 CPackedControlSetPackedControlSet stores the data of a combination of FFs within one control set (clock enable/preset-reset/clock) that can be packed in a site
 CPackingCLBSitePackingCLBSite is a container for the packing information (parameters, candidates and packing status) of a specific DeviceInfo::DeviceSite
 CPackingCLBClusterPackingCLBCluster is a container of cells/PlacementUnits which can be packed in the corresponding CLB site
 CSiteBELMappingSiteBELMapping is a contain recording the mapping between cells and BELs
 CPULocationPULocation is a helper class to find the neighbor PlacementUnits with KD-Tree
 CPlacementInfoInformation related to FPGA placement (wirelength optimization, cell spreading, legalization, packing)
 C_ClockNetCoverageRetangular clock region coverage of a clock net
 CCellBinInfoRecord the bin information for a cell (BELtype, column/row, resource demand)
 CClusterNetThe net between the objects of ClusterUnit class
 CClusterUnitGroup of PlacementUnits
 CCompatiblePlacementTableDescribes the type mapping from design to device, where a cell can be placed (which BEL in which site)
 CLocation
 CPlacementBinInfoBEL bin for global placement for a specific shared BEL type
 CPlacementHybridBinInfoBEL bin for global placement for multiple specific shared BEL types
 CPlacementMacroFixed group of multiple standard cells with constraints of their relative locations
 C_fixedPlacementInfo_inMacroSome constaints of elements' relative locations are defined by the design. We need to record this
 CPlacementNetPlacement net, compared to design net, includes information related to placement
 C_pinOffset
 CPlacementSiteBinInfoSite bin for global placement for some specific Site types
 CPlacementSiteTypeInfoInformation for a site, e.g. what BEL in site and where are these kind of sites
 Clocation
 CPlacementUnitMovement unit in placement with information of location and resource demand
 CPlacementUnpackedCellSmallest, indivisible, representable component. It will include only one standard cell
 CPlacementTimingInfoPlacementTimingInfo is the container which record the timing information related to placement
 CTimingGraphDirected graph for timing analysis
 CTimingEdgeTimingEdge records a directed interconnection relationship between two TimingNode. It is a point-to-point information instead of HyperEdge
 CTimingNodeTimingNode is the node in TimingGraph, which could be pin or cell in the design netlist
 CPlacementTimingOptimizer
 CProcessFuncInterface
 CQPSolverWrapper
 CsolverDataType
 CsolverSettingsType
 CSAPlacer
 CWirelengthOptimizerWirelengthOptimizer builds numerical models based on the element locations and calls solvers to find an optimal solution of the placement
 C_CellWithScore
 C_PUWithScore
 C_slackEnhanceTuple