file opt / cplex.opt /;
put opt;
put 'iis no';
put /;
*obliga a gams a utilizar el disco duro para los nodos
put 'nodefileind 2';
put /;
*tolerancia de las infactibilidad
put 'eprhs 1e-04';
put /;
*metodo de resolución automático
put 'lpmethod 0';
put /;
putclose opt;
*Para que te coja el fichero
Modelo.OptFile = 1;
jueves, 29 de julio de 2010
sábado, 17 de julio de 2010
Generar numeros aleatorios en gams
Scalar
cc;
execute_load 'seed',cc=cc;
execseed=cc;
seq(reg) = uniformint(1,100);
cc = execseed;
execute_load 'seed',cc;
El número pseudo-aleatorio se usa como semilla para la siguiente vez qeu se ejecute el programa
cc;
execute_load 'seed',cc=cc;
execseed=cc;
seq(reg) = uniformint(1,100);
cc = execseed;
execute_load 'seed',cc;
El número pseudo-aleatorio se usa como semilla para la siguiente vez qeu se ejecute el programa
Implementación de un backtracking Variaciones sin repetición
void variac(int n, int m, int j, vector& used, vector& seq)
{
if(j == m){
for(unsigned int i=0;i cout << seq[i] + 1<<",";
cout << endl;
}
else{
for(int i=0;i if(!used[i]){
used[i] = true;
seq[j] = i;
variac(n,m,j+1,used,seq);
used[i] = false;
}
}
}
}
int main(){
int n = 5;
int m = 2;
for(int i=0;i used.push_back(false);
for(int i=0;i seq.push_back(0);
variac(n,m,0,used,seq);
}
{
if(j == m){
for(unsigned int i=0;i
cout << endl;
}
else{
for(int i=0;i
used[i] = true;
seq[j] = i;
variac(n,m,j+1,used,seq);
used[i] = false;
}
}
}
}
int main(){
int n = 5;
int m = 2;
for(int i=0;i
for(int i=0;i
variac(n,m,0,used,seq);
}
Suscribirse a:
Entradas (Atom)