File: GetAllPosteriorDraws.m

package info (click to toggle)
dynare 6.4-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 67,648 kB
  • sloc: cpp: 79,109; ansic: 28,917; objc: 12,430; yacc: 4,528; pascal: 1,993; lex: 1,441; sh: 1,129; python: 634; makefile: 626; lisp: 163; xml: 18
file content (97 lines) | stat: -rw-r--r-- 4,083 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
function draws = GetAllPosteriorDraws(options_, dname, fname, column, FirstMhFile, FirstLine, TotalNumberOfMhFile, NumberOfDraws, nblcks, blck)

% Gets all posterior draws.
%
% INPUTS
% - options_               [struct]   Dynare's options.
% - dname                  [char]     name of directory with results.
% - fname                  [char]     name of mod file.
% - column                 [integer]  scalar, parameter index.
% - FirstMhFile            [integer]  scalar, first MH file.
% - FirstLine              [integer]  scalar, first line in first MH file.
% - TotalNumberOfMhFile    [integer]  scalar, total number of MH file.
% - NumberOfDraws          [integer]  scalar, number of posterior draws.
% - nblcks                 [integer]  scalar, total number of blocks.
% - blck:                  [integer]  scalar, desired block to read.
%
% OUTPUTS
% - draws:                 [double]   NumberOfDrawsĂ—1 vector, draws from posterior distribution.
%
% REMARKS
% Only the first and third input arguments are required for SMC samplers.

% Copyright © 2005-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/>.

if ishssmc(options_)
    % Load draws from the posterior distribution
    pfiles = dir(sprintf('%s/hssmc/particles-*.mat', dname));
    posterior = load(sprintf('%s/hssmc/particles-%u-%u.mat', dname, length(pfiles), length(pfiles)));
    draws = transpose(posterior.particles(column,:));
else
    iline = FirstLine;
    linee = 1;
    DirectoryName = CheckPath('metropolis',dname);
    if nblcks>1 && nargin<10
        draws = zeros(NumberOfDraws*nblcks,1);
        iline0=iline;
        if column>0
            for blck = 1:nblcks
                iline=iline0;
                for file = FirstMhFile:TotalNumberOfMhFile
                    load([DirectoryName '/'  fname '_mh' int2str(file) '_blck' int2str(blck)],'x2')
                    NumberOfLines = size(x2(iline:end,:),1);
                    draws(linee:linee+NumberOfLines-1) = x2(iline:end,column);
                    linee = linee+NumberOfLines;
                    iline = 1;
                end
            end
        else
            for blck = 1:nblcks
                iline=iline0;
                for file = FirstMhFile:TotalNumberOfMhFile
                    load([DirectoryName '/'  fname '_mh' int2str(file) '_blck' int2str(blck)],'logpo2')
                    NumberOfLines = size(logpo2(iline:end),1);
                    draws(linee:linee+NumberOfLines-1) = logpo2(iline:end);
                    linee = linee+NumberOfLines;
                    iline = 1;
                end
            end
        end
    else
        if nblcks==1
            blck=1;
        end
        if column>0
            for file = FirstMhFile:TotalNumberOfMhFile
                load([DirectoryName '/'  fname '_mh' int2str(file) '_blck' int2str(blck)],'x2')
                NumberOfLines = size(x2(iline:end,:),1);
                draws(linee:linee+NumberOfLines-1) = x2(iline:end,column);
                linee = linee+NumberOfLines;
                iline = 1;
            end
        else
            for file = FirstMhFile:TotalNumberOfMhFile
                load([DirectoryName '/'  fname '_mh' int2str(file) '_blck' int2str(blck)],'logpo2')
                NumberOfLines = size(logpo2(iline:end,:),1);
                draws(linee:linee+NumberOfLines-1) = logpo2(iline:end);
                linee = linee+NumberOfLines;
                iline = 1;
            end
        end
    end
end