-
Notifications
You must be signed in to change notification settings - Fork 4
/
main.m
39 lines (30 loc) · 1.55 KB
/
main.m
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
%% Script for applying the MD model to experimental JV data
% -------------------------------------------------------------------------
% The JV data used in this script are imported from an example file. You
% can create a txt file containing your experimental JV data in the same
% format, and apply the MD model to your data by specifying the `fileName`
% variable.
%
% @ Author: Minshen Lin
% @ Institution: Zhejiang University
%
% @ LICENSE
% This program 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.
% -------------------------------------------------------------------------
clear; clc; % Clear workspace
addpath(genpath(pwd)); % Include directories
perov = Device(); % Initialize Device object with default constructor
perov.L = 750e-7; % Specify the thickness of the active layer [cm]
perov.tBulk = 398e-9; % Specify the bulk SRH recombination lifetime [ns]
perov.Eg = 1.55; % Specify the active layer bandgap [eV]
fileName = "/Experimental Data/passivated_reverse_scan.txt"; % Load data
dataJV = DataPreconditioner(fileName).dataJV; % Data preconditioning
retrievedParams = fittingMD(perov, dataJV); % MD model fitting
calJV = solver(perov, dataJV, retrievedParams); % Numerically solve JV
plotJV(dataJV, calJV, retrievedParams); % Plot JV curves
% Loss analysis
PCEs = lossAnalysis(dataJV, calJV, perov, retrievedParams);
plotNormPCEGain(PCEs);