Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026 #include <dieselSpray/injectorType.H>
00027
00028
00029
00030 namespace Foam
00031 {
00032
00033 defineTypeNameAndDebug(injectorType, 0);
00034 defineRunTimeSelectionTable(injectorType, dictionary);
00035
00036 }
00037
00038
00039
00040
00041
00042 Foam::injectorType::injectorType
00043 (
00044 const Foam::Time&,
00045 const Foam::dictionary&
00046 )
00047 {}
00048
00049
00050
00051 Foam::autoPtr<Foam::injectorType> Foam::injectorType::New
00052 (
00053 const Time& t,
00054 const dictionary& dict
00055 )
00056 {
00057 word injectorTypeName
00058 (
00059 dict.lookup("injectorType")
00060 );
00061
00062 Info<< "Selecting injectorType "
00063 << injectorTypeName << endl;
00064
00065 dictionaryConstructorTable::iterator cstrIter =
00066 dictionaryConstructorTablePtr_->find(injectorTypeName);
00067
00068 if (cstrIter == dictionaryConstructorTablePtr_->end())
00069 {
00070 FatalError
00071 << "injectorType::New(const dictionary&) : " << endl
00072 << " unknown injectorType type "
00073 << injectorTypeName
00074 << ", constructor not in hash table" << endl << endl
00075 << " Valid injector types are :" << endl;
00076 Info<< dictionaryConstructorTablePtr_->sortedToc() << abort(FatalError);
00077 }
00078
00079 return autoPtr<injectorType>(cstrIter()(t, dict));
00080
00081 }
00082
00083
00084
00085
00086 Foam::injectorType::~injectorType()
00087 {}
00088
00089 Foam::scalar Foam::injectorType::getTableValue
00090 (
00091 const List<pair>& table,
00092 const scalar value
00093 ) const
00094 {
00095
00096 label i = 0;
00097
00098
00099 label maxRow = table.size() - 1;
00100
00101
00102 if (value < table[0][0])
00103 {
00104 return table[0][1];
00105 }
00106
00107 else if (value > table[maxRow][0])
00108 {
00109 return table[maxRow][1];
00110 }
00111
00112 else
00113 {
00114 while
00115 (
00116 (i < maxRow-1) && (table[i+1][0] < value)
00117 )
00118 {
00119 i++;
00120 }
00121
00122 return table[i][1]
00123 + (value-table[i][0])/(table[i+1][0]-table[i][0])
00124 * (table[i+1][1]-table[i][1]);
00125 }
00126 }
00127
00128 Foam::scalar Foam::injectorType::integrateTable
00129 (
00130 const List<pair>& table,
00131 const scalar value
00132 ) const
00133 {
00134 label N = table.size() - 1;
00135 scalar sum = 0.0;
00136 scalar t = max(table[0][0], min(value, table[N][0]));
00137
00138 label i = 0;
00139 while
00140 (
00141 (i < N - 1)
00142 && (table[i+1][0] < t)
00143 )
00144 {
00145 scalar deltaH = table[i+1][1] + table[i][1];
00146 scalar deltaT = table[i+1][0] - table[i][0];
00147 sum += 0.5*deltaH*deltaT;
00148 i++;
00149 }
00150
00151 scalar interpolatedValue =
00152 table[i][1]
00153 + (t - table[i][0])
00154 * (table[i+1][1] - table[i][1])
00155 / (table[i+1][0] - table[i][0]);
00156
00157 sum +=
00158 0.5*(interpolatedValue + table[i][1])
00159 *(t - table[i][0]);
00160
00161 return sum;
00162 }
00163
00164 Foam::scalar Foam::injectorType::integrateTable
00165 (
00166 const List<pair>& table
00167 ) const
00168 {
00169 scalar integratedTable = 0.0;
00170 for (label i=0; i < table.size() - 1; i++)
00171 {
00172 scalar deltaH = table[i+1][1] + table[i][1];
00173 scalar deltaT = table[i+1][0] - table[i][0];
00174 integratedTable += 0.5*deltaH*deltaT;
00175 }
00176
00177 return integratedTable;
00178 }
00179
00180