82 lines
3.3 KiB
Matlab
82 lines
3.3 KiB
Matlab
|
function [particles, tlogpostkernel, loglikelihood, SimulationFolder] = smc_samplers_initialization(funobj, sampler, n, Prior, SimulationFolder, nsteps)
|
|||
|
|
|||
|
% Initialize SMC samplers by drawing initial particles in the prior distribution.
|
|||
|
%
|
|||
|
% INPUTS
|
|||
|
% - TargetFun [char] string specifying the name of the objective function (posterior kernel).
|
|||
|
% - sampler [char] name of the sampler.
|
|||
|
% - n [integer] scalar, number of particles.
|
|||
|
% - mh_bounds [double] p×2 matrix defining lower and upper bounds for the estimated parameters.
|
|||
|
% - dataset_ [dseries] sample
|
|||
|
% - dataset_info [struct] informations about the dataset
|
|||
|
% - options_ [struct] dynare's options
|
|||
|
% - M_ [struct] model description
|
|||
|
% - estim_params_ [struct] estimated parameters
|
|||
|
% - bayestopt_ [struct] estimated parameters
|
|||
|
% - oo_ [struct] outputs
|
|||
|
%
|
|||
|
% OUTPUTS
|
|||
|
% - ix2 [double] p×n matrix of particles
|
|||
|
% - ilogpo2 [double] n×1 vector of posterior kernel values for the particles
|
|||
|
% - iloglik2 [double] n×1 vector of likelihood values for the particles
|
|||
|
% - ModelName [string] name of the mod-file
|
|||
|
% - MetropolisFolder [string] path to the Metropolis subfolder
|
|||
|
% - bayestopt_ [structure] estimation options structure
|
|||
|
%
|
|||
|
% SPECIAL REQUIREMENTS
|
|||
|
% None.
|
|||
|
|
|||
|
% Copyright © 2022-2023 Dynare Team
|
|||
|
%
|
|||
|
% This file is part of Dynare.
|
|||
|
%
|
|||
|
% Dynare is free software: you can redistribute it and/or modify
|
|||
|
% it under the terms of the GNU General Public License as published by
|
|||
|
% the Free Software Foundation, either version 3 of the License, or
|
|||
|
% (at your option) any later version.
|
|||
|
%
|
|||
|
% Dynare is distributed in the hope that it will be useful,
|
|||
|
% but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|||
|
% MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|||
|
% GNU General Public License for more details.
|
|||
|
%
|
|||
|
% You should have received a copy of the GNU General Public License
|
|||
|
% along with Dynare. If not, see <https://www.gnu.org/licenses/>.
|
|||
|
|
|||
|
dprintf('Estimation:%s: Initialization...', sampler)
|
|||
|
|
|||
|
% Delete old mat files storign particles if any...
|
|||
|
matfiles = sprintf('%s%sparticles*.mat', SimulationFolder, filesep());
|
|||
|
files = dir(matfiles);
|
|||
|
if ~isempty(files)
|
|||
|
delete(matfiles);
|
|||
|
dprintf('Estimation:%s: Old %s-files successfully erased.', sampler, sampler)
|
|||
|
end
|
|||
|
|
|||
|
% Simulate a pool of particles characterizing the prior distribution (with the additional constraint that the likelihood is finite)
|
|||
|
set_dynare_seed('default');
|
|||
|
dprintf('Estimation:%s: Searching for initial values...', sampler);
|
|||
|
particles = zeros(Prior.length(), n);
|
|||
|
tlogpostkernel = zeros(n, 1);
|
|||
|
loglikelihood = zeros(n, 1);
|
|||
|
|
|||
|
t0 = tic;
|
|||
|
parfor j=1:n
|
|||
|
notvalid = true;
|
|||
|
while notvalid
|
|||
|
candidate = Prior.draw();
|
|||
|
if Prior.admissible(candidate)
|
|||
|
particles(:,j) = candidate;
|
|||
|
[tlogpostkernel(j), loglikelihood(j)] = tempered_likelihood(funobj, candidate, 0.0, Prior);
|
|||
|
if isfinite(loglikelihood(j)) % if returned log-density is Inf or Nan (penalized value)
|
|||
|
notvalid = false;
|
|||
|
end
|
|||
|
end
|
|||
|
end
|
|||
|
end
|
|||
|
tt = toc(t0);
|
|||
|
|
|||
|
save(sprintf('%s%sparticles-1-%u.mat', SimulationFolder, filesep(), nsteps), 'particles', 'tlogpostkernel', 'loglikelihood')
|
|||
|
dprintf('Estimation:%s: Initial values found (%.2fs)', sampler, tt)
|
|||
|
skipline()
|