Xyce  6.1
Xyce::Device::MemristorYakopcic::Model Class Reference

#include <N_DEV_MemristorYakopcic.h>

Inheritance diagram for Xyce::Device::MemristorYakopcic::Model:
Collaboration diagram for Xyce::Device::MemristorYakopcic::Model:

Public Types

typedef std::vector< Instance * > InstanceVector
 

Public Member Functions

 Model (const Configuration &configuration, const ModelBlock &model_block, const FactoryBlock &factory_block)
 
 ~Model ()
 
void addInstance (Instance *instance)
 
virtual void forEachInstance (DeviceInstanceOp &op) const
 
virtual std::ostream & printOutInstances (std::ostream &os) const
 
virtual bool processParams ()
 processParams More...
 
virtual bool processInstanceParams ()
 processInstanceParams More...
 
- Public Member Functions inherited from Xyce::Device::DeviceModel
 DeviceModel (const ModelBlock &model_block, ParametricData< void > &parametric_data, const FactoryBlock &factory_block)
 
virtual ~DeviceModel ()
 
const std::string & getName () const
 
void setModParams (const std::vector< Param > &params)
 
virtual std::ostream & printName (std::ostream &os) const
 
virtual bool clearTemperatureData ()
 
void saveParams ()
 
bool interpolateTNOM (double)
 
bool interpolateDOSE (double)
 
void restoreParams ()
 
virtual bool getBinPrefixFlag ()
 
int getLevel () const
 
void setLevel (int level)
 
const std::string & getType () const
 
- Public Member Functions inherited from Xyce::Device::DeviceEntity
 DeviceEntity (ParametricData< void > &parametric_data, const SolverState &solver_state, const DeviceOptions &device_options, const std::string &netlist_filename, int netlist_line)
 
virtual ~DeviceEntity ()
 
virtual CompositeParamconstructComposite (const std::string &composite_name, const std::string &param_name)
 
bool setDefaultParam (double val, bool overrideOriginal=false)
 
double getDefaultParam () const
 
bool scaleParam (const std::string &paramName, double val, double val0)
 
bool scaleParam (const std::string &paramName, double val)
 
bool scaleDefaultParam (double val)
 
bool analyticSensitivityAvailable (const std::string &paramName)
 
bool analyticSensitivityAvailableDefaultParam ()
 
bool getAnalyticSensitivity (const std::string &paramName, std::vector< double > &dfdpVec, std::vector< double > &dqdpVec, std::vector< double > &dbdpVec, std::vector< int > &FindicesVec, std::vector< int > &QindicesVec, std::vector< int > &BindicesVec)
 
bool getAnalyticSensitivityDefaultParam (std::vector< double > &dfdpVec, std::vector< double > &dqdpVec, std::vector< double > &dbdpVec, std::vector< int > &FindicesVec, std::vector< int > &QindicesVec, std::vector< int > &BindicesVec)
 
bool setParam (const std::string &paramName, double val, bool overrideOriginal=false)
 
bool getParam (const std::string &paramName, double &result) const
 
bool findParam (const std::string &param_name) const
 
bool getParamBreakpoints (std::vector< Util::BreakPoint > &)
 
bool updateDependentParameters (const Linear::Vector &vars)
 
bool updateDependentParameters (double temp_tmp)
 
bool updateGlobalParameters (GlobalParameterMap &)
 
bool updateDependentParameters ()
 
double setDependentParameter (Util::Param &, double *, ParameterType::ExprAccess)
 
double setDependentParameter (Util::Param &, std::vector< double > *, int, ParameterType::ExprAccess)
 
void setDependentParameter (Util::Param &par, Depend &dependentParam, ParameterType::ExprAccess depend)
 
void setDefaultParams ()
 
void setParams (const std::vector< Param > &params)
 
bool given (const std::string &parameter_name) const
 
void setDefaultParamName (const std::string &default_param_name)
 
const std::vector< Depend > & getDependentParams ()
 
void addDependentParameter (const Depend &param)
 
const DeviceOptionsgetDeviceOptions () const
 
const SolverStategetSolverState () const
 
const NetlistLocation & netlistLocation () const
 
const ParameterMapgetParameterMap () const
 
- Public Member Functions inherited from Xyce::Device::ParameterBase
 ParameterBase ()
 
virtual ~ParameterBase ()
 
double getOriginalValue (int serial_number)
 
void setOriginalValue (int serial_number, double value)
 
bool wasValueGiven (int serial_number) const
 
void setValueGiven (int serial_number, bool value)
 

Private Member Functions

 Model ()
 
 Model (const Model &)
 
Modeloperator= (const Model &)
 

Private Attributes

InstanceVector instanceContainer
 
double Eta_
 
double Vp_
 
double Vn_
 
double Ap_
 
double An_
 
double A1_
 
double A2_
 
double B_
 
double AlphaP_
 
double AlphaN_
 
double XP_
 
double XN_
 
double xScaling_
 
bool randomResNoiseOn_
 
int randomResNoiseSeed_
 
double randomResNoiseLambda_
 
double randomResNoiseMean_
 
double randomResNoiseSD_
 
double randomResUpdateTime_
 
double randomResEpsilonUpdateTime_
 
double randomResDelta_
 
double randomResDeltaGrad_
 
bool randomXNoiseOn_
 
int randomXNoiseSeed_
 
double randomXNoiseLambda_
 
double randomXNoiseMean_
 
double randomXNoiseSD_
 
double randomXUpdateTime_
 
double randomXEpsilonUpdateTime_
 
double randomXDelta_
 
double randomXDeltaGrad_
 
Xyce::Util::RandomNumbers * randomNumberGen_
 

Friends

class ParametricData< Model >
 
class Instance
 
class Traits
 
class Master
 

Additional Inherited Members

- Static Public Member Functions inherited from Xyce::Device::DeviceModel
template<class T >
static void initThermalModel (ParametricData< T > &parametric_data)
 Add the parameter "TEMPMODEL" to the parametric_data. More...
 
template<class T >
static void initDoseModel (ParametricData< T > &parametric_data)
 Add the parameter "DOSEMODEL" to the parametric_data. More...
 
- Protected Attributes inherited from Xyce::Device::DeviceEntity
std::vector< int > expVarGIDs
 
std::vector< int > expVarLIDs
 
std::vector< std::string > expVarNames
 
std::vector< double > expVarVals
 
std::vector< double > eVarVals
 

Detailed Description

Definition at line 307 of file N_DEV_MemristorYakopcic.h.

Member Typedef Documentation

Constructor & Destructor Documentation

Xyce::Device::MemristorYakopcic::Model::Model ( const Configuration configuration,
const ModelBlock model_block,
const FactoryBlock factory_block 
)

Definition at line 1236 of file N_DEV_MemristorYakopcic.C.

Xyce::Device::MemristorYakopcic::Model::~Model ( )

Definition at line 1304 of file N_DEV_MemristorYakopcic.C.

Xyce::Device::MemristorYakopcic::Model::Model ( )
private
Xyce::Device::MemristorYakopcic::Model::Model ( const Model )
private

Member Function Documentation

void Xyce::Device::MemristorYakopcic::Model::addInstance ( Instance instance)
inline

Definition at line 343 of file N_DEV_MemristorYakopcic.h.

void Xyce::Device::MemristorYakopcic::Model::forEachInstance ( DeviceInstanceOp op) const
virtual

Implements Xyce::Device::DeviceModel.

Definition at line 1375 of file N_DEV_MemristorYakopcic.C.

Model& Xyce::Device::MemristorYakopcic::Model::operator= ( const Model )
private
std::ostream & Xyce::Device::MemristorYakopcic::Model::printOutInstances ( std::ostream &  os) const
virtual

Implements Xyce::Device::DeviceModel.

Definition at line 1339 of file N_DEV_MemristorYakopcic.C.

bool Xyce::Device::MemristorYakopcic::Model::processInstanceParams ( )
virtual

processInstanceParams

Returns
true if parameter processing was successful

Implements Xyce::Device::DeviceModel.

Definition at line 1209 of file N_DEV_MemristorYakopcic.C.

bool Xyce::Device::MemristorYakopcic::Model::processParams ( )
virtual

processParams

Returns
true if parameter processing was successful

Implements Xyce::Device::DeviceModel.

Definition at line 1185 of file N_DEV_MemristorYakopcic.C.

Friends And Related Function Documentation

friend class Instance
friend

Definition at line 310 of file N_DEV_MemristorYakopcic.h.

friend class Master
friend

Definition at line 312 of file N_DEV_MemristorYakopcic.h.

friend class ParametricData< Model >
friend

Definition at line 309 of file N_DEV_MemristorYakopcic.h.

friend class Traits
friend

Definition at line 311 of file N_DEV_MemristorYakopcic.h.

Member Data Documentation

double Xyce::Device::MemristorYakopcic::Model::A1_
private

Definition at line 364 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::A2_
private

Definition at line 365 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::AlphaN_
private

Definition at line 368 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::AlphaP_
private

Definition at line 367 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::An_
private

Definition at line 363 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::Ap_
private

Definition at line 362 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::B_
private

Definition at line 366 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::Eta_
private

Definition at line 359 of file N_DEV_MemristorYakopcic.h.

InstanceVector Xyce::Device::MemristorYakopcic::Model::instanceContainer
private

Definition at line 356 of file N_DEV_MemristorYakopcic.h.

Xyce::Util::RandomNumbers* Xyce::Device::MemristorYakopcic::Model::randomNumberGen_
private

Definition at line 394 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomResDelta_
private

Definition at line 383 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomResDeltaGrad_
private

Definition at line 384 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomResEpsilonUpdateTime_
private

Definition at line 382 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomResNoiseLambda_
private

Definition at line 378 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomResNoiseMean_
private

Definition at line 379 of file N_DEV_MemristorYakopcic.h.

bool Xyce::Device::MemristorYakopcic::Model::randomResNoiseOn_
private

Definition at line 376 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomResNoiseSD_
private

Definition at line 380 of file N_DEV_MemristorYakopcic.h.

int Xyce::Device::MemristorYakopcic::Model::randomResNoiseSeed_
private

Definition at line 377 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomResUpdateTime_
private

Definition at line 381 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomXDelta_
private

Definition at line 392 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomXDeltaGrad_
private

Definition at line 393 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomXEpsilonUpdateTime_
private

Definition at line 391 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomXNoiseLambda_
private

Definition at line 387 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomXNoiseMean_
private

Definition at line 388 of file N_DEV_MemristorYakopcic.h.

bool Xyce::Device::MemristorYakopcic::Model::randomXNoiseOn_
private

Definition at line 385 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomXNoiseSD_
private

Definition at line 389 of file N_DEV_MemristorYakopcic.h.

int Xyce::Device::MemristorYakopcic::Model::randomXNoiseSeed_
private

Definition at line 386 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::randomXUpdateTime_
private

Definition at line 390 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::Vn_
private

Definition at line 361 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::Vp_
private

Definition at line 360 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::XN_
private

Definition at line 370 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::XP_
private

Definition at line 369 of file N_DEV_MemristorYakopcic.h.

double Xyce::Device::MemristorYakopcic::Model::xScaling_
private

Definition at line 375 of file N_DEV_MemristorYakopcic.h.


The documentation for this class was generated from the following files: