当前位置: 首页>>代码示例>>C++>>正文


C++ Spectrum::initSpectrum方法代码示例

本文整理汇总了C++中Spectrum::initSpectrum方法的典型用法代码示例。如果您正苦于以下问题:C++ Spectrum::initSpectrum方法的具体用法?C++ Spectrum::initSpectrum怎么用?C++ Spectrum::initSpectrum使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Spectrum的用法示例。


在下文中一共展示了Spectrum::initSpectrum方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: main

int main()
{
    int c;
    target=imread("../archivos/pozo_real_big.png",CV_32FC3);
    target.convertTo(target,CV_32FC3,1.0/255);

    fuente.initSpectrum(DEFAULT_START_LAMDA,DEFAULT_END_LAMDA,1000);
	fuente.setGausian(1,LAMDA_0,10e-9);
	muestra.initMuestra(163e-6,163e-6,7.030674847e6);
	muestra.setMuestraPlain(1,IN_VISIBILITY);
    muestra.setMuestraFromFile("../archivos/pozo.png",1,IN_DEPTH,0,0);
	if (camara.setSpectrumsFiles("../archivos/r1.dat","../archivos/g1.dat","../archivos/b1.dat")){
        return -1;
	};
    camara.initFPS(1146,1146,30,COLOR);
	interf.initInterferometro(&muestra,&fuente,&camara,camara.exposureTime());




    srand ( time(NULL) );
	ag.PoblacionAleatoria(10,nBytes); //creo una poblacion de 200 individuos, de longitud 'nBytes' cada string
	ag.FuncionEvaluacion(eval); //defino cual es la funcion que evalua cada cromosoma y devuelve el fitnes entre 0 y 1 (Es llamada automaticamante por al AG
    ag.dTasaMutacion = 0.05; //tasa de mutacion de 0 a 1
    CLASECromosoma *ap,alfa,beta;

    while(1) {
         imshow("target",target);
        c = cvWaitKey(2);
        if ((char)c==27){
            break;
        }
    }
    printf("comienza\n");
    do {
 		ag.Generacion(); //creo una nueva generacion de individuos
    	ap = ag.SeleccionarMejor();
        if (!(ag.Edad()%1)) {//cada 500 iteraciones muestre la mejor solucion
            printf ("\n[%d] ",(int)ag.Edad());
            printf ("Best: %.3f\tPob:%.3f",ap->Fitness(),ag.Fitness());
            imshow("eval",getImg(ap->Cromosoma));
        }
        c = cvWaitKey(2);
        if ((char)c==27){
            break;
        }
    } while (ap->Fitness()<0.9 && (ag.Edad()<10000)); //condicion de parada el fitness de la mejor solucion
    printf ("\n\tGen: %d",(int)ag.Edad()); //imprimo la edad de la poblacion: numero de iteraciones totales ejecutadas (generaciones)
    for (;;) {
        c = cvWaitKey(2);
        if ((char)c==27){
            break;
        }
    }
    return 0;
}
开发者ID:nvelozsavino,项目名称:tesis-nico,代码行数:56,代码来源:main.cpp


注:本文中的Spectrum::initSpectrum方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。