class parameters:
    def __init__(self):
        self.INDEX = {}   # persistent INDEX
        self.p = {}       # persistent parameter dictionary
        self.init_all_parameters()

    def init_all_parameters(self):
        INDEX = self.INDEX
        p = self.p

        # vector indices/mapping
        # state variables
        INDEX['X_T'] = 0
        INDEX['X_CO2'] = 1
        INDEX['X_H'] = 2
        INDEX['X_B'] = 3
        INDEX['X_T_v_mean'] = 4
        INDEX['X_T_vsum'] = 5
        INDEX['X_C_buf'] = 6
        INDEX['X_C_fruit'] = 7
        INDEX['X_C_leaf'] = 8
        INDEX['X_C_stem'] = 9
        INDEX['X_R_fruit'] = 10
        INDEX['X_R_leaf'] = 11
        INDEX['X_R_stem'] = 12
        INDEX['X_max'] = 13

        # output variables
        INDEX['Y_T'] = 0
        INDEX['Y_CO2'] = 1
        INDEX['Y_H'] = 2
        INDEX['Y_T_v'] = 3
        INDEX['Y_max'] = 4

        # input variables
        INDEX['U_Vent'] = 0
        INDEX['U_CO2'] = 1
        #INDEX['U_temp'] = 2
        INDEX['U_heat'] = 2
        INDEX['U_cool'] = 3
        INDEX['U_max'] = 4

        # disturbance variables
        INDEX['D_T_out'] = 0
        INDEX['D_C_out'] = 1
        INDEX['D_RH_out'] = 2
        INDEX['D_R_o'] = 3
        INDEX['D_max'] = 4

        # flux variables - GH
        INDEX['phi_QT_sun'] = 0
        INDEX['phi_QT_vent'] = 1
        INDEX['phi_QT_wall'] = 2
        INDEX['phi_QT_roof'] = 3
        INDEX['phi_QT_cov'] = 4
        INDEX['phi_QT_trans'] = 5
        INDEX['phi_QT_v_i'] = 6
        INDEX['phi_R_i'] = 7
        INDEX['phi_QCO2_vent'] = 8
        INDEX['phi_QCO2_ass'] = 9
        INDEX['phi_QCO2_inj'] = 10
        INDEX['phi_H_cov'] = 11
        INDEX['phi_H_vent'] = 12
        INDEX['phi_H_trans'] = 13

        # flux variables - Plant
        INDEX['phi_MC_buf_fruit'] = 14
        INDEX['phi_MC_buf_leaf'] = 15
        INDEX['phi_MC_buf_stem'] = 16
        INDEX['phi_MC_buf_i'] = 17
        INDEX['phi_MC_fruit_i'] = 18
        INDEX['phi_MC_leaf_i'] = 19
        INDEX['phi_MC_stem_i'] = 20
        INDEX['phi_MC_leaf_prune'] = 21
        INDEX['phi_MC_i_buf'] = 22
        INDEX['phi_max'] = 22

        # Parameters related to environment/ GH
        p['T_k'] = 0  # 273.15; Temp in Kelvin gor 0°C
        p['tau_cov'] = 0.85  # Light transmission of the cover material
        p['tau_scr'] = 0.83  # Light transmission of the day screen
        p['tau_scr2'] = 0.28  # Light transmission of the energy screen
        p['Cl_scr'] = 100  # Assume the screen is closed when R_o < 3 W m-2
        p['Cl_scr2'] = 100  # Assume the screen is closed when R_o < 3 W m-2
        p['V_gh'] = 2058.24  # Volume of the GH m3
        p['A_floor'] = 307.2  # Area of the GH floor m2
        p['c_air'] = 1003.2  # Specific heat capacity of humid air [J kg-1 K-1]
        p['rho_air'] = 1.2041  # Density of air (20 ◦C) [kg m-3]
        p['u_wall'] = 1.7  # Ug-value of the glass wall (cover) [W m-2 K-1]
        p['u_roof'] = 5.8  # Ug-value of the glass roof (cover) [W m-2 K-1]
        p['d_leaf'] = 0.1  # characteristic leaf length [m]
        p['msd_v'] = 1.326  # surface density [kg m-2]
        p['v_i'] = 0.1  # internal air speed [m s-1]
        p['LAI'] = 1.8  # Leaf area Index [m2 m-2]
        p['gamma'] = 0.4  # Crop specific parameter -Tomato
        p['T_sp'] = 24.5  # + p['T_k; Set point temperature
        p['L'] = 2240  # L - amount of energy needed to evaporate water from a leaf/ [J g-1] Latent heat of vaporization of water 22.6 * 10^5; [J kg-1]
        p['g'] = 9.81  # acceleration due to gravity [m s-2]
        p['nu'] = 15.1e-6  # kinematic viscosity of air [m2 s-1]
        p['lambda'] = 0.025  # thermal conductivity of air [W m-1 K-1]
        p['u_CO2_max'] = 7.792 * 10 ** -4 *10**3 # Max. CO2 supply [g s-1]
        p['A_cov'] = 750.31  # Total surface area of the walls [m2]
        p['N_A'] = 6.02214e+23  # Avogadro's number
        p['atm'] = 1.013e5  # standard atmospheric pressure [Pa]

        # Paramters related to crop and photosynthesis model
        p['C_buf_max'] = 0.02  # maximum buffer capacity per unit area of cultivated floor [kg{CH2O} m-2 s-1]
        p['s_min_T'] = -0.8690  # differential switch function slope for minimum photosynthesis instantaneous temperature [1/°C]
        p['s_max_T'] = 0.5793  # differential switch function slope for maximum photosynthesis instantaneous temperature [1/°C]
        p['T_min_v'] = 6  # between base temperature and first optimal temperature [°C]
        p['T_max_v'] = 40  # between second optimal temperature and maximum temperature [°C]
        p['s_min_T24'] = -1.1587  # differential switch function slope for minimum photosynthesis mean 24 hour temperature [1/°C]
        p['s_max_T24'] = 1.3904  # differential switch function slope for maximum photosynthesis mean 24 hour temperature [1/°C]
        p['T_min_v24'] = 12  # between base temperature and first optimal temperature for 24 hour mean [°C]
        p['T_max_v24'] = 27  # between second optimal temperature and maximum temperature for 24 hour mean [°C]
        p['T_sum_end'] = 1035  # the temperature sum at which point the fruit growth rate is maximal [oC]
        p['rg_fruit'] = 0.328e-6  # potential fruit growth rate coefficient at 20 °C [kg{CH2O} m-2 s-1]
        p['rg_leaf'] = 0.095e-6  # potential leaf growth rate coefficient at 20 °C [kg{CH2O} m-2 s-1]
        p['rg_stem'] = 0.074e-6  # potential stem growth rate coefficient at 20 °C [kg{CH2O} m-2 s-1]
        p['c_fruit_g'] = 0.27  # fruit growth respiration coefficient [-]
        p['c_leaf_g'] = 0.28  # leaf growth respiration coefficient [-]
        p['c_stem_g'] = 0.30  # stem growth respiration coefficient [-]
        p['Q10'] = 2  # see parameters for de Zwart model above [-]
        p['c_RGR'] = 2.85e6  # regression coefficient in maintenance respiration function [s]
        p['c_fruit_m'] = 1.16e-7  # fruit maintenance respiration coefficient [1/s]
        p['c_leaf_m'] = 3.47e-7  # leaf maintenance respiration coefficient [1/s]
        p['c_stem_m'] = 1.47e-7  # stem maintenance respiration coefficient [1/s]
        p['LAI_max'] = 5  # the maximum allowed leaf area index [m^2{leaf}/m^2{floor}]
        p['SLA'] = 26.6  # specific leaf area index [m^2{leaf}/kg{CH2O}]
        p['P_heat'] = 110 * 10 ** 3  # Heating capacity of Chiller [W]
        p['P_cool'] = 80 * 10 ** 3  # Cooling capacity of Chiller [W]

        # photosynthesis
        p['c_Gamma'] = 1.7e-6  # effect of canopy temperature on CO2 compensation point [mol{CO2}/mol{air}/K]
        p['s_airbuf_buf'] = 5e2  # differential switch function slope for maximum buffer capacity [m^2/kg]
        p['s_buforg_buf'] = -5e3  # differential switch function slope for minimum buffer capacity [m^2/kg]
        p['M_a'] = 0.029  # molar mass of dry air [kg/mol]
        p['M_c'] = 0.044  # molar mass of CO2 [kg/mol]
        p['M_w'] = 0.018  # molar mass of water [kg/mol]
        p['M_carb'] = 0.03  # molar mass of CH2O [kg/mol]
        p['eta'] = 0.67  # conversion factor from CO2 in the air to CO2 in the stomata [-]
        p['J_max_25'] = 210e-6  # maximum rate of electron transport at 25 C [mol{e}/m^2{leaf}/s]
        p['E_j'] = 37e3  # activation energy for J_pot calculation [J/mol]
        p['R'] = 8.314  # gas constant [J/mol/K]
        p['S'] = 710  # entropy term for J_pot calculation [J/mol/K]
        p['HH'] = 22e4  # deactivation energy for J_pot calculation [J/mol]
        p['alph'] = 0.385  # conversion factor from photons to electrons [mol{e}/mol{phot}]
        p['theta'] = 0.7  # degree of curvature of the electron transport rate [-]
        p['heat_phot'] = 3.6368e-19  # conversion rate from incident energy to number of photons [num{photons}/J]

        p['c_v'] = 4180  # heat capacity of vegetation [J kg-1 K-1]
        p['msd_v'] = 1.326  # surface density of vegetation [kg/m^2]

        # Photosynthesis New
        p['Fp'] = 0.3 # fraction PAR absorbed by nonphotosynthetic issues
        p['zeta'] = 4.59 # µmol[photons] J-1, zeta - conversion factor
        p['p_o2i'] = 210 # mbar - p_o2i - O2 partial pressure inside the stomata
        p['f_oc'] = 0.21 # f_oc - ratio of V_omax (max. oxygenation rate) to V_cmax (max. carboxylation rate)
        p['Kc_25'] = 310 # mbar - Michaelis-Menten constant Rubisco carboxylation
        p['Ec'] = 59356 # J mol-1 - Activation energy Kc
        p['Ko_25'] = 155  # µbar - Ko_25 - Michaelis-Menten constant Rubisco oxygenation
        p['Eo'] = 35948  # J mol-1 - Activation energy Ko
        p['T0'] = 273.15  # J mol-1 - Activation energy Ko
        p['T25'] = p['T0'] + 25  # Placeholder for T25 since it's calculated later
        p['Ko_25'] = 155 # J mol-1 - Activation energy Ko
        p['Ro'] = 35948  # J mol-1 - Activation energy Ko
        p['S'] = 710 # constant - J mol-1 K-1
        p['H'] = 220000  # J mol-1 - Activation energy Ko
        p['Ej'] = 37000  # J mol-1 - Activation energy Jmax max electron transport rate
        p['rho_chl'] = 0.45 # g[Chl] m-2[leaf] - Superficial chlorophyll density
        p['MCO2'] = 44e-9  # kg[CO2] µmol-1[CO2]
        p['Evc'] = 58520  # kg[CO2] µmol-1[CO2]
        p['k_C'] = 2.5 # s-1 - Turnover number of RuP2 (carboxylase)
        p['Et'] = 87 #µmol[CO2] g-1[Chl] - Total concentration of enzyme sites
        p['rho_co2'] = 1.98e-6 # mg[CO2] m-3[CO2] - CO2 density at T0 - 273.15 K
        p['r_25DL_mol'] = 1.1 # µmol[CO2] m-2[leaf] s-1 - Dark respiration at 25°C
        p['Ed'] = 66405 # J mol-1 - Activation energy rD dark respiration rate
        p['p_w'] = 94 # percentage water in total fresh weight biomass
        p['A_s'] = 0.9 * p['A_floor']
        p['c_f'] = 1 # fraction of produced biomass material for dry weight 
        p['c_cs'] = 30 / 44 # kg[CH2O] kg[CO2]-1 - conversion factor from CO2 to CH20
        p['ASRQ'] = 1.2 # kg[CH2O] kg[dW]-1 - conversion factor from dry weight to CH20 (glucose req.)
        p['R_cut'] = 2000 #  s m-1 - leaf cuticular resistance
        p['R_min'] = 82.003 #sm-1 - minimum internal crop resistance
        p['Le'] = 0.89 #[-]

        # Parameters related to humidity due to heating and cooling
        p['A_uc'] = 684.46 # m2
        p['c_air'] = 1000 
        p['T_uc'] = p['T0'] + 7 # Temperature of the upper cooling pipe
        p['M_h2o'] = 18*10^-3 # Molar mass of water - [kg mol-1]
        p['cs1'] = 610.780
        p['cs2'] = 17.08085
        p['cs3'] = 234.175
        p['neta_heat'] = 4.43 * 10**-5 # g[h2o] J-1 - amount of vapor released when 1 joule of sensible energy is produced by air heater
        p['d_uc'] = 0.1 # [m] - diameter of spiral fin tube

        p['vPower'] = 0.44 # kW
        p['cPower'] = 40 # kW

        p['T_ref'] = 19 # Reference temperature to maintain the temperature deviation
        p['n_day'] = 86400 # Number of seconds in a day [s day-1]

        # Initial values
        INITVAL = {}
        INITVAL['X'] = [0] * (INDEX['X_max'] + 1)
        INITVAL['U'] = [0] * (INDEX['U_max'] + 1)
        INITVAL['D'] = [0] * (INDEX['D_max'] + 1)
        INITVAL['Y'] = [0] * (INDEX['Y_max'] + 1)

        # packing all parameters into one structure
        p['INDEX'] = INDEX
        p['INITVAL'] = INITVAL
    
    def get_all_parameters(self):
        return self.INDEX, self.p