Class IdfReader
- Namespace
- EpNet
- Assembly
- EpNet.dll
Provides methods to manipulate an idf model by accessing to the different idf classes and their fields.
public class IdfReader : List<IdfObject>- Inheritance
- 
      objectList<IdfObject>IdfReader
- Extension Methods
Examples
var Idf = new IdfReader();
foreach (var m in Idf["Material"].Where(m=>m["Name"].Contains("Insulation")))
m["Conductivity"].Number = 0.03;Constructors
IdfReader(bool)
Initializes a new instance of the IdfReader class.
By default, this constructor loads in.idf and Energy+.idd from the standard DesignBuilder installation path.
public IdfReader(bool initializeDefaults = true)Parameters
- initializeDefaultsbool
- If - true(default), initializes the IdfReader by loading- in.idfand- Energy+.iddfrom DesignBuilder's EnergyPlus installation path. If- false, creates an empty IdfReader.
IdfReader(string)
Creates an IdfReader object loading Energy+.idd from the standard DesignBuilder installation path.
public IdfReader(string idfFile)Parameters
- idfFilestring
- Path to an idf file or a string with the contents of the file 
IdfReader(string, Idd)
Creates an IdfReader object from an idf file path (or text content) and the Idd object from another IdfReader.
public IdfReader(string idfFile, Idd idd)Parameters
- idfFilestring
- Path to an idf file or a string with the contents of the file 
- iddIdd
- Reference to the Idd from another IdfReader 
IdfReader(string, string)
Creates an IdfReader object from an idf file path (or text content) and the path to Energy+.idd file.
public IdfReader(string idfFile, string iddFilePath)Parameters
- idfFilestring
- Path to an idf file or a string with the contents of the file 
- iddFilePathstring
- Path to the Energy+.idd file corresponding to the E+ version of the idf file. 
Properties
DsbFileName
Filename of the dsb file from which the idf has been generated.
public string DsbFileName { get; }Property Value
- string
- dsb filename 
DsbFolder
Folder where the original dsb file is located.
public string DsbFolder { get; }Property Value
- string
- dsb file folder 
DsbPath
Full path of the dsb file from which the idf has been generated.
public string DsbPath { get; }Property Value
- string
- Path of the dsb file. 
EnergyPlusPath
public string EnergyPlusPath { get; set; }Property Value
Idd
Reference to the Idd object that holds the variable names from the Energy+.idd
public Idd Idd { get; set; }Property Value
- Idd
- Idd object 
Idf
Provides a single Idf instance to be shared between scripts.
public static IdfReader Idf { get; }Property Value
IdfEncoding
Gets or sets the encoding used for reading and writing the IDF file. Default encoding is UTF-8.
public Encoding IdfEncoding { get; set; }Property Value
IdfPath
Path to the idf file
public string IdfPath { get; set; }Property Value
- string
- Path to the loaded idf file 
this[string]
List of all the idf objects from the specified idf class.
public List<IdfObject> this[string idfClass] { get; }Parameters
- idfClassstring
- idf class to use as a filter 
Property Value
- List<IdfObject>
- idf objects list from a class 
Examples
var allZones = Idf["Zone"];this[string[]]
List of all the idf objects from the specified idf classes.
public List<IdfObject> this[params string[] idfClasses] { get; }Parameters
- idfClassesstring[]
- idf classes to use as a filter 
Property Value
- List<IdfObject>
- idf objects list from a list of classes 
Examples
var zoneEquipment = Idf["ZoneHVAC:FourPipeFanCoil","ZoneHVAC:PackagedTerminalAirConditioner","ZoneHVAC:PackagedTerminalHeatPump"];Methods
Add(IdfObject)
Adds a new IdfObject to the IdfReader.
public void Add(IdfObject value)Parameters
- valueIdfObject
- The IdfObject to be added. 
AddDesignVariable(string, string, int, string)
Adds a design variable for parametric/optimisation. Use in BeforeEnergySimulation hook.
public void AddDesignVariable(string idfClass, string name, int field, string variableKey)Parameters
- idfClassstring
- The idf class for the object to modify. e.g. "Material" 
- namestring
- Name of the object to modify. e.g. Insulation (searches for a name starting by that) 
- fieldint
- Number of the field to change. e.g. 2 
- variableKeystring
- Name of the variable key given in DesignBuilder as Custom IDF. e.g. "insulationthickness" 
Examples
Test different thickness values for a insulation material: AddDesignVariable("Material","Variable Insulation", 2, "insulationthickness"); Idf.Save();
AddDesignVariable(string, string, int, string, Func<double, double>)
Adds a design variable for parametric/optimisation. Use in BeforeEnergySimulation hook.
public void AddDesignVariable(string idfClass, string name, int field, string variableKey, Func<double, double> variableKeyFunction)Parameters
- idfClassstring
- The idf class for the object to modify. e.g. "Material" 
- namestring
- Name of the object to modify. e.g. Insulation (searches for a name starting by that) 
- fieldint
- Number of the field to change. e.g. 2 
- variableKeystring
- Name of the variable key given in DesignBuilder as Custom IDF e.g. "insulationthickness" 
- variableKeyFunctionFunc<double, double>
- Function to apply to the variableKey 
Examples
Test different thickness values for a insulation material: AddDesignVariable("Material","Variable Insulation", 2, "insulationthickness", x=>x/100); Idf.Save();
AddKpi(Environment, string, double)
Adds a Kpi result for parametric/optimisatin. Use in AfterEnergySimulation hook. Also as an extension method for DB.Api.Environment ApiEnvironment)
public void AddKpi(Environment ApiEnvironment, string kpiName, double kpiValue)Parameters
Clone()
Creates a clone of the current IdfReader instance, including its list of IdfObjects. The cloned instance will have the same properties and a new copy of the IdfObjects.
public IdfReader Clone()Returns
- IdfReader
- A new IdfReader instance that is a deep clone of the current one. 
Clone(IdfObject)
Makes a copy of a specified idf object and add it to the idf model.
public void Clone(IdfObject idfObject)Parameters
- idfObjectIdfObject
- idf object to clone. 
GetByIdfClasses(IEnumerable<string>)
Retrieves a list of IdfObjects filtered by the specified IDF classes.
public List<IdfObject> GetByIdfClasses(IEnumerable<string> idfClasses)Parameters
- idfClassesIEnumerable<string>
- An enumerable containing the IDF class names to filter. 
Returns
- List<IdfObject>
- A list of IdfObjects that match the given IDF classes. 
GetDataFromEso(string)
Retrieves a value from the eso file saved with the SaveDataInEso method.
public double? GetDataFromEso(string key)Parameters
- keystring
- Name of the key or variable to retrieve. 
Returns
GetVariable(string)
Gets the value of the parametric variable defined in DesignBuilder optimization module as a Custom Idf variable.
public string GetVariable(string name)Parameters
- namestring
- Variable key used in DesignBuilder 
Returns
- string
- String holding the value of the variable. 
Load(string)
Loads a portion of idf to an existing idf model. Do not include comments.
public void Load(string idf)Parameters
- idfstring
- Text containing the idf to load. 
Load(string[])
Loads a single IdfObject its sequence of elements
public void Load(string[] fields)Parameters
- fieldsstring[]
- idfclass, field1, field2 ... 
ReadData(string)
Reads data from the precomments of the file
public string ReadData(string key)Parameters
- keystring
Returns
RemoveData(string)
Removes data from the precomments of the file
public void RemoveData(string key)Parameters
- keystring
Save(bool)
Saves the idf file overwriting the original.
public void Save(bool comments = true)Parameters
- commentsbool
- Include idf comments in the file. 
Save(string, bool, bool)
Saves the idf file.
public void Save(string idfFilePath, bool comments = true, bool ordered = false)Parameters
- idfFilePathstring
- Path for the idf file. Use filename only to save in original idf folder. 
- commentsbool
- Include idf comments in the file. 
- orderedbool
- Order idf clases by name. 
SaveASCII(bool)
Saves the idf file overwriting the original.
public void SaveASCII(bool comments = true)Parameters
- commentsbool
- Include idf comments in the file. 
SaveASCII(string, bool, bool)
Saves the idf file removing diacritics (á,é,ü...) and Spanish ñ
public void SaveASCII(string idfFilePath, bool comments = true, bool ordered = false)Parameters
- idfFilePathstring
- Path for the idf file. Use filename only to save in original idf folder. 
- commentsbool
- Include idf comments in the file. 
- orderedbool
- Order idf clases by name. 
SaveDataInEso(string, double)
Creates a numeric value than can be retrieved after simulation from the Eso results file.
public void SaveDataInEso(string key, double value)Parameters
- keystring
- Name of the key or variable to be used later for retrieval. 
- valuedouble
- Value of the variable 
ToString()
Whole idf content as a text string.
public override string ToString()Returns
- string
- idf content. 
WriteData(string, string)
Writes data to the precomments of the file
public void WriteData(string key, string value)