2020-02-14 18:40:59 -06:00
|
|
|
#include "arch_direct.h"
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
#include "vtr_assert.h"
|
|
|
|
|
2020-02-14 18:40:59 -06:00
|
|
|
/************************************************************************
|
|
|
|
* Member functions for class ArchDirect
|
|
|
|
***********************************************************************/
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
* Constructors
|
|
|
|
***********************************************************************/
|
2022-10-06 19:08:50 -05:00
|
|
|
ArchDirect::ArchDirect() { return; }
|
2020-02-14 18:40:59 -06:00
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
* Public Accessors : aggregates
|
|
|
|
***********************************************************************/
|
|
|
|
ArchDirect::arch_direct_range ArchDirect::directs() const {
|
|
|
|
return vtr::make_range(direct_ids_.begin(), direct_ids_.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
2022-10-06 19:08:50 -05:00
|
|
|
* Public Accessors
|
2020-02-14 18:40:59 -06:00
|
|
|
***********************************************************************/
|
|
|
|
ArchDirectId ArchDirect::direct(const std::string& name) const {
|
|
|
|
if (0 < direct_name2ids_.count(name)) {
|
|
|
|
return direct_name2ids_.at(name);
|
|
|
|
}
|
|
|
|
return ArchDirectId::INVALID();
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string ArchDirect::name(const ArchDirectId& direct_id) const {
|
|
|
|
/* validate the direct_id */
|
|
|
|
VTR_ASSERT(valid_direct_id(direct_id));
|
2022-10-06 19:08:50 -05:00
|
|
|
return names_[direct_id];
|
2020-02-14 18:40:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
CircuitModelId ArchDirect::circuit_model(const ArchDirectId& direct_id) const {
|
|
|
|
/* validate the direct_id */
|
|
|
|
VTR_ASSERT(valid_direct_id(direct_id));
|
2022-10-06 19:08:50 -05:00
|
|
|
return circuit_models_[direct_id];
|
2020-02-14 18:40:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
e_direct_type ArchDirect::type(const ArchDirectId& direct_id) const {
|
|
|
|
/* validate the direct_id */
|
|
|
|
VTR_ASSERT(valid_direct_id(direct_id));
|
2022-10-06 19:08:50 -05:00
|
|
|
return types_[direct_id];
|
2020-02-14 18:40:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
e_direct_direction ArchDirect::x_dir(const ArchDirectId& direct_id) const {
|
|
|
|
/* validate the direct_id */
|
|
|
|
VTR_ASSERT(valid_direct_id(direct_id));
|
2022-10-06 19:08:50 -05:00
|
|
|
return directions_[direct_id].x();
|
2020-02-14 18:40:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
e_direct_direction ArchDirect::y_dir(const ArchDirectId& direct_id) const {
|
|
|
|
/* validate the direct_id */
|
|
|
|
VTR_ASSERT(valid_direct_id(direct_id));
|
2022-10-06 19:08:50 -05:00
|
|
|
return directions_[direct_id].y();
|
2020-02-14 18:40:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
|
|
|
* Public Mutators
|
|
|
|
***********************************************************************/
|
|
|
|
ArchDirectId ArchDirect::add_direct(const std::string& name) {
|
|
|
|
if (0 < direct_name2ids_.count(name)) {
|
|
|
|
return ArchDirectId::INVALID();
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This is a legal name. we can create a new id */
|
|
|
|
ArchDirectId direct = ArchDirectId(direct_ids_.size());
|
|
|
|
direct_ids_.push_back(direct);
|
|
|
|
names_.push_back(name);
|
|
|
|
circuit_models_.push_back(CircuitModelId::INVALID());
|
|
|
|
types_.emplace_back(NUM_DIRECT_TYPES);
|
2022-10-06 19:08:50 -05:00
|
|
|
directions_.emplace_back(vtr::Point<e_direct_direction>(
|
|
|
|
NUM_DIRECT_DIRECTIONS, NUM_DIRECT_DIRECTIONS));
|
2020-02-14 18:40:59 -06:00
|
|
|
|
|
|
|
/* Register in the name-to-id map */
|
|
|
|
direct_name2ids_[name] = direct;
|
2022-10-06 19:08:50 -05:00
|
|
|
|
2020-02-14 18:40:59 -06:00
|
|
|
return direct;
|
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void ArchDirect::set_circuit_model(const ArchDirectId& direct_id,
|
|
|
|
const CircuitModelId& circuit_model) {
|
2020-02-14 18:40:59 -06:00
|
|
|
/* validate the direct_id */
|
|
|
|
VTR_ASSERT(valid_direct_id(direct_id));
|
2022-10-06 19:08:50 -05:00
|
|
|
circuit_models_[direct_id] = circuit_model;
|
2020-02-14 18:40:59 -06:00
|
|
|
}
|
|
|
|
|
2022-10-06 19:08:50 -05:00
|
|
|
void ArchDirect::set_type(const ArchDirectId& direct_id,
|
|
|
|
const e_direct_type& type) {
|
2020-02-14 18:40:59 -06:00
|
|
|
/* validate the direct_id */
|
|
|
|
VTR_ASSERT(valid_direct_id(direct_id));
|
2022-10-06 19:08:50 -05:00
|
|
|
types_[direct_id] = type;
|
2020-02-14 18:40:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
void ArchDirect::set_direction(const ArchDirectId& direct_id,
|
|
|
|
const e_direct_direction& x_dir,
|
|
|
|
const e_direct_direction& y_dir) {
|
|
|
|
/* validate the direct_id */
|
|
|
|
VTR_ASSERT(valid_direct_id(direct_id));
|
2022-10-06 19:08:50 -05:00
|
|
|
directions_[direct_id].set_x(x_dir);
|
|
|
|
directions_[direct_id].set_y(y_dir);
|
2020-02-14 18:40:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
/************************************************************************
|
2022-10-06 19:08:50 -05:00
|
|
|
* Internal invalidators/validators
|
2020-02-14 18:40:59 -06:00
|
|
|
***********************************************************************/
|
|
|
|
/* Validators */
|
|
|
|
bool ArchDirect::valid_direct_id(const ArchDirectId& direct_id) const {
|
2022-10-06 19:08:50 -05:00
|
|
|
return (size_t(direct_id) < direct_ids_.size()) &&
|
|
|
|
(direct_id == direct_ids_[direct_id]);
|
2020-02-14 18:40:59 -06:00
|
|
|
}
|