⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 checkvarsdata.m

📁 遗传规划的matlab工具箱
💻 M
字号:
function [data,params]=checkvarsdata(start,continuing,data,params);
%CHECKVARSDATA    Fills the dataset variable for the GPLAB algorithm.
%   CHECKVARSDATA(START,CONTINUE,DATA,PARAMS) returns the dataset
%   on which the GPLAB algorithm will run, after prompting the user
%   for the names of the files containing this data.
%
%   [DATA,PARAMS]=CHECKVARSDATA(START,CONTINUE,PARAMS) also
%   returns the updated algorithm parameters.
%
%   Input arguments:
%      START - true if no generations have been run yet (boolean)
%      CONTINUE - true if some generations have been run (boolean)
%      DATA - the current dataset for the algorithm to run (array)
%      PARAMS - the algorithm running parameters (struct)
%   Output arguments:
%      DATA - the dataset on which the algorithm will run (struct)
%      PARAMS - the algorithm running parameters (struct)
%
%   See also CHECKVARSSTATE, CHECKVARSPARAMS, GPLAB
%
%   Copyright (C) 2003-2004 Sara Silva (sara@dei.uc.pt)
%   Acknowledgements: SINTEF (hso@sintef.no; jtt@sintef.no; okl@sintef.no)
%   This file is part of the GPLAB Toolbox

% check training data variables:

if start
   
   % ask for the name of the files:
   parentdir=strrep(which(mfilename),strcat(mfilename,'.m'),'');
   
   % training data:
   if isempty(params.datafilex) % if not in params, ask user
   	filenamex=input('Please name the file (with extension) containing the input data: ','s');
   else
      filenamex=params.datafilex;
   end
   if isempty(findstr(filenamex,filesep))
	   % if file was not given with path, use parentdir (where this file is):
      filenamex=strcat(parentdir,filenamex);
   end
   params.datafilex=filenamex;
   x=load(params.datafilex); % load the file
   
	if isempty(params.datafiley) % if not in params, ask user
   	filenamey=input('Please name the file (with extension) containing the desired output: ','s');
   else
      filenamey=params.datafiley;
   end
   if isempty(findstr(filenamey,filesep))
      % if file was not given with path, use parentdir (where this file is):
      filenamey=strcat(parentdir,filenamey);
   end
   params.datafiley=filenamey;
   y=load(params.datafiley); % load the file
   
   
   % test data:
   if params.usetestdata
      
		if isempty(params.testdatafilex)
   		testfilenamex=input('Please name the file (with extension) containing the test input data: ','s');
      else
      	testfilenamex=params.testdatafilex;
      end
      if isempty(findstr(testfilenamex,filesep))
         testfilenamex=strcat(parentdir,testfilenamex);
      end
      params.testdatafilex=testfilenamex;
      testx=load(params.testdatafilex); % load the file
      
		if isempty(params.testdatafiley)
   		testfilenamey=input('Please name the file (with extension) containing the test desired output: ','s');
   	else
      	testfilenamey=params.testdatafiley;
      end
      if isempty(findstr(testfilenamey,filesep))
	      testfilenamey=strcat(parentdir,testfilenamey);
      end
      params.testdatafiley=testfilenamey;
      testy=load(params.testdatafiley); % load the file
      
   end %if params.usetestdata
   
	% create variable for the algorithm:
   data=feval(params.files2data,x,y);
   if params.usetestdata   	
	   data.test=feval(params.files2data,testx,testy);
   end
   
   % examples for training are now vectors containing the input data:
   %      data.example(1,:)=[0.75,0.25,0.25,0.25];
   %      data.result(1)=[0,0];
   %      data.example(2,:)=[0.875,0.625,0.625,0.625];
   %      data.result(2)=[1,2];
   % test data is something like:
   %      data.test.example(1,:)=[0.85,0.5,0.5,0.75];
   %      data.test.result(1)=[0,1];
   %      data.test.example(2,:)=[0.5,0.25,0.25,0.0];
   %      data.test.result(2)=[1,3];
   
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -