Skip to content

Commit

Permalink
- improved goal function evaluation
Browse files Browse the repository at this point in the history
git-svn-id: https://openmodelica.org/svn/OpenModelica/trunk@20653 f25d12d1-65f4-0310-ae8a-bbce733d8d8e
  • Loading branch information
Vitalij Ruge committed May 16, 2014
1 parent a56005d commit db88c49
Showing 1 changed file with 12 additions and 5 deletions.
17 changes: 12 additions & 5 deletions SimulationRuntime/c/optimization/eval_all/EvalF.c
Expand Up @@ -63,14 +63,23 @@ Bool evalfF(Index n, Number * vopt, Bool new_x, Number *objValue, void * useData
modelica_real *** v = optData->v;
long double erg = 0.0;
long double erg1 = 0.0;
long double erg0[np];
int i,j;

for(i = 0; i + 1 < nsi; ++i){
for(j = 0; j< np; ++j){
erg0[j] = v[0][j][il];
}

for(i = 1; i + 1 < nsi; ++i){
for(j = 0; j< np; ++j){
erg += b[j]*v[i][j][il];
erg0[j] += v[i][j][il];
}
}

for(j = 0; j< np; ++j){
erg += b[j]*erg0[j];
}

i = nsi - 1;
for(j = 0; j< np; ++j)
erg1 += b[j]*v[i][j][il];
Expand Down Expand Up @@ -130,10 +139,8 @@ Bool evalfDiffF(Index n, double * vopt, Bool new_x, Number *gradF, void * useDat
if(ma){
const int k = optData->s.derIndex[1];
modelica_real * gradM = optData->J[nsi - 1][np -1][k];

int i, ii;

if(la){
int i, ii;
for(i = 0, ii = n - nv; i < nv; ++i, ++ii)
gradF[ii] += gradM[i];
}else{
Expand Down

0 comments on commit db88c49

Please sign in to comment.