#include "v_pwm24.h"
//#include "DSP281x_Device.h"     // DSP281x Headerfile Include File
//#include "big_dsp_module.h"
//#include "rmp2cntl.h"        	// Include header for the VHZPROF object
//#include "rmp_cntl_my1.h"        	// Include header for the VHZPROF object
#include "pid_reg3.h"        	// Include header for the VHZPROF object

#include "params.h"
// #include "PWMTools.h"
#include "adc_tools.h"
#include "v_pwm24.h"

#include "dq_to_alphabeta_cos.h"

#include "IQmathLib.h"
// #include "log_to_memory.h"
//Xilinx
//#include "x_parameters.h"
// #include "x_basic_types.h"
// #include "xp_project.h"
// #include "xp_cds_tk.h"
#include "svgen_dq.h"
#include "xp_write_xpwm_time.h"

#include "def.h"

#define DEF_FREQ_PWM_XTICS 	T1_PRD
#define DEF_PERIOD_MIN_XTICS 	(DT + 10e-6)*FTBCLK

// ×àñòîòà ØÈÌ â xilinx òèêàõ (60000000 / 16 / FREQ_PWM = 3750000 / FREQ_PWM)
// #pragma DATA_SECTION(VAR_FREQ_PWM_XTICS,".fast_vars1");
int VAR_FREQ_PWM_XTICS = DEF_FREQ_PWM_XTICS;

// Ìèíèìàëüíîå çíà÷åíèå ØÈÌà â xilinx òèêàõ
// #pragma DATA_SECTION(VAR_PERIOD_MAX_XTICS,".fast_vars1");
int VAR_PERIOD_MAX_XTICS = DEF_FREQ_PWM_XTICS - DEF_PERIOD_MIN_XTICS;

// Ìèíèìàëüíîå çíà÷åíèå ØÈÌà â xilinx òèêàõ (mintime+deadtime) (Fïèëû * Tìèí.êëþ÷à.ñåê = (60 / 16 / 2) * Tìêñ = (60  * Tìêñ / 16 / 2))
// #pragma DATA_SECTION(VAR_PERIOD_MIN_XTICS,".fast_vars1");
int VAR_PERIOD_MIN_XTICS = DEF_PERIOD_MIN_XTICS;// 

// Ìèíèìàëüíîå çíà÷åíèå ØÈÌà â xilinx òèêàõ äëÿ òîðìîçíûõ êëþ÷åé (mintime) (Fïèëû * Tìèí.êëþ÷à.ñåê = (60 / 16 / 2) * Tìêñ = (60  * Tìêñ / 16 / 2))
// #pragma DATA_SECTION(VAR_PERIOD_MIN_BR_XTICS,".fast_vars1");
// int VAR_PERIOD_MIN_BR_XTICS = DEF_PERIOD_MIN_BR_XTICS;// 

#define PWM_ONE_INTERRUPT_RUN       1
#define PWM_TWICE_INTERRUPT_RUN     0



#define SQRT3 29058990  //1.7320508075688772935274463415059
#define CONST_IQ_1  16777216 //1
#define CONST_IQ_05  8388608 //0.5
#define CONST_IQ_2	33554432 //2

#define CONST_IQ_PI6  8784530	//30
#define CONST_IQ_PI3  17569060  // 60 
#define CONST_IQ_PI   52707178  // 180
#define CONST_IQ_OUR1 35664138  //
#define CONST_IQ_2PI  105414357 // 360
#define CONST_IQ_120G 35138119  // 120 grad
#define CONST_IQ_3 50331648 // 3

#define IQ_ALFA_SATURATION1 15099494//16441671//15099494
#define IQ_ALFA_SATURATION2 1677721//16441671//15099494


#define PI 3.1415926535897932384626433832795

// #pragma DATA_SECTION(iq_alfa_coef,".fast_vars");
_iq iq_alfa_coef = 16777216;

// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
//#pragma DATA_SECTION(freq_array,".v_24pwm_vars");
//int freq_array[COUNT_VAR_FREQ];
// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

//#pragma DATA_SECTION(pidCur_Kp,".v_24pwm_vars");
//_iq pidCur_Kp = 0;

// #pragma DATA_SECTION(pidCur_Ki,".fast_vars");
_iq pidCur_Ki = 0;

// #pragma DATA_SECTION(ar_tph,".fast_vars");
_iq ar_tph[7];

// #pragma DATA_SECTION(winding_displacement,".fast_vars");
_iq winding_displacement = CONST_IQ_PI6;

//#pragma DATA_SECTION(iq_koef_mod_korrect_1,".fast_vars");//v_24pwm_vars
//_iq iq_koef_mod_korrect_1;

//#pragma DATA_SECTION(iq_koef_mod_korrect_2,".v_24pwm_vars");
//_iq iq_koef_mod_korrect_2;

//#pragma DATA_SECTION(ar_sa_all,".v_24pwm_vars");
// #pragma DATA_SECTION(ar_sa_all,".fast_vars");
int ar_sa_all[3][6][4][7] = { { 
							{
									{-1,0,0,0,1,1,1},{0,1,1,1,0,0,0},{0,0,1,1,1,0,0},{0,1,1,1,0,0,0}
							},
							{
									{-1,-1,0,0,0,1,1},{-1,-1,0,0,0,0,0},{-1,0,0,0,1,0,0},{0,0,1,1,0,0,0}
							},
							{
									{-1,-1,-1,0,0,0,1},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0}
							},
							{
									{-1,-1,-1,0,0,0,1},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0}
							},
							{
									{-1,-1,0,0,0,1,1},{-1,-1,0,0,0,0,0},{-1,0,0,0,1,0,0},{0,0,1,1,0,0,0}
							},
							{
									{-1,0,0,0,1,1,1},{0,1,1,1,0,0,0},{0,0,1,1,1,0,0},{0,1,1,1,0,0,0}
							}
						 },
							{
							{
									{-1,-1,0,0,0,1,1},{-1,-1,0,0,0,0,0},{-1,0,0,0,1,0,0},{0,0,1,1,0,0,0}
							},
							{
									{-1,0,0,0,1,1,1},{0,1,1,1,0,0,0},{0,0,1,1,1,0,0},{0,1,1,1,0,0,0}
							},
							{
									{-1,0,0,0,1,1,1},{0,1,1,1,0,0,0},{0,0,1,1,1,0,0},{0,1,1,1,0,0,0}
							},
							{
									{-1,-1,0,0,0,1,1},{-1,-1,0,0,0,0,0},{-1,0,0,0,1,0,0},{0,0,1,1,0,0,0}
							},
							{
									{-1,-1,-1,0,0,0,1},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0}
							},
							{
									{-1,-1,-1,0,0,0,1},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0}
							}
						 },
						{
							{
									{-1,-1,-1,0,0,0,1},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0}
							},
							{
									{-1,-1,-1,0,0,0,1},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0},{-1,-1,-1,0,0,0,0}
							},
							{
									{-1,-1,0,0,0,1,1},{-1,-1,0,0,0,0,0},{-1,0,0,0,1,0,0},{0,0,1,1,0,0,0}
							},
							{
									{-1,0,0,0,1,1,1},{0,1,1,1,0,0,0},{0,0,1,1,1,0,0},{0,1,1,1,0,0,0}
							},
							{
									{-1,0,0,0,1,1,1},{0,1,1,1,0,0,0},{0,0,1,1,1,0,0},{0,1,1,1,0,0,0}
							},
							{
									{-1,-1,0,0,0,1,1},{-1,-1,0,0,0,0,0},{-1,0,0,0,1,0,0},{0,0,1,1,0,0,0}
							}
						 }
					};


// #pragma DATA_SECTION(svgen_pwm24_1,".v_24pwm_vars");
//#pragma DATA_SECTION(svgen_pwm24_1,".fast_vars");
SVGEN_PWM24 svgen_pwm24_1 = SVGEN_PWM24_DEFAULTS;
// #pragma DATA_SECTION(svgen_pwm24_2,".v_24pwm_vars");
//#pragma DATA_SECTION(svgen_pwm24_2,".fast_vars");
SVGEN_PWM24 svgen_pwm24_2 = SVGEN_PWM24_DEFAULTS;

// #pragma DATA_SECTION(svgen_dq_1,".v_24pwm_vars");
SVGENDQ svgen_dq_1 = SVGENDQ_DEFAULTS;
// #pragma DATA_SECTION(svgen_dq_2,".v_24pwm_vars");
SVGENDQ svgen_dq_2 = SVGENDQ_DEFAULTS;

//#pragma DATA_SECTION(delta_t1_struct,".v_24pwm_vars");
//#pragma DATA_SECTION(delta_t1_struct,".fast_vars");
//PIDREG3 delta_t1_struct = PIDREG3_DEFAULTS;
//#pragma DATA_SECTION(delta_t2_struct,".v_24pwm_vars");
//#pragma DATA_SECTION(delta_t2_struct,".fast_vars");
//PIDREG3 delta_t2_struct = PIDREG3_DEFAULTS;

void calc_t_abc(_iq k, _iq teta, int region, _iq *iq_tt0, _iq *iq_tt1, _iq *iq_tt2, _iq *iq_tt3, _iq *iq_tt4, _iq *iq_tt5);
void set_predel_dshim24(SVGEN_PWM24_TIME *T,int16 dmin,int16 dmax);
void set_predel_dshim24_simple0(SVGEN_PWM24_TIME *T,int16 dmin,int16 dmax);
void set_predel_dshim24_simple1(SVGEN_PWM24_TIME *T,int16 dmin,int16 dmax);
int detect_sec(_iq teta);
int detect_region(_iq k, _iq teta);
//




//void init_alpha(void)
//{
//
////  power_ain1.init(&power_ain1);
////  power_ain2.init(&power_ain2);
//
//    svgen_mf1.NewEntry = 0;//_IQ(0.5);
//    svgen_mf2.NewEntry = 0;
//
//    svgen_mf1.SectorPointer = 0;
//    svgen_mf2.SectorPointer = 0;
//
////ñäâèã ïî óìîë÷àíèþ 0 ãðàäóñîâ
//    svgen_mf1.Alpha = _IQ(0);
//    svgen_mf2.Alpha = _IQ(0);
//
//
//
//
//
//#if (SETUP_SDVIG_OBMOTKI == SDVIG_OBMOTKI_30_PLUS)
//// 30 ãðàä. ñäâèã
//    svgen_mf1.Alpha = _IQ(0.5);
//    svgen_mf2.Alpha = _IQ(0);
//
//    svgen_mf1.Full_Alpha = svgen_mf1.Alpha;
//    svgen_mf2.Full_Alpha = svgen_mf2.Alpha;
//#else
//
//
//#if (SETUP_SDVIG_OBMOTKI == SDVIG_OBMOTKI_30_MINUS)
//// -30 ãðàä. ñäâèã
//    svgen_mf1.Alpha = _IQ(0);
//    svgen_mf2.Alpha = _IQ(0.5);
//    svgen_mf1.Full_Alpha = svgen_mf1.Alpha;
//    svgen_mf2.Full_Alpha = svgen_mf2.Alpha;
//#else
//
//#if (SETUP_SDVIG_OBMOTKI ==  SDVIG_OBMOTKI_ZERO)
//// -30 ãðàä. ñäâèã
//    svgen_mf1.Alpha = _IQ(0);
//    svgen_mf2.Alpha = _IQ(0);
//    svgen_mf1.Full_Alpha = svgen_mf1.Alpha;
//    svgen_mf2.Full_Alpha = svgen_mf2.Alpha;
//#else
//   #error "!!!ÎØÈÁÊÀ!!! Íå îïðåäåëåí SETUP_SDVIG_OBMOTKI â params_motor.h!!!"
//
//
//#endif
//
//#endif
//
//
//
//#endif
//
//
//
//}

void InitVariablesSvgen(unsigned int freq)
{
////////// Inserted from 'initPWM_Variables' for modulation project //////////

	//Äëÿ ïåðâîé ïèëû çàêðûòî, êîãäà âûøå çàäàííîãî óðîâíÿ, äëÿ âòîðîé íèæå
    xpwm_time.Tclosed_0 = 0;
    xpwm_time.Tclosed_1 = VAR_FREQ_PWM_XTICS + 1;
    xpwm_time.Tclosed_high = VAR_FREQ_PWM_XTICS + 1;
    xpwm_time.pwm_tics = VAR_FREQ_PWM_XTICS;
    // âûáðàëè íàïðàâëåíèå ïèë
    // "íàïðàâëåíèå ïèë äëÿ ØÈÌà òèïà=0x0
    //Åñëè SAW_DIRECTbit = 0 òî çíà÷åíèå ïèëû>óñòàâêè âûñòàâèò àêòèâíîå âêëþ÷åííîå ñîñòîÿíèå=0
    //íà âûõîäå ØÈÌà
    //Åñëè SAW_DIRECTbit = 1 òî çíà÷åíèå ïèëû<=óñòàâêè âûñòàâèò àêòèâíîå âêëþ÷åííîå ñîñòîÿíèå=0
    //íà âûõîäå ØÈÌà
    // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
    //Äëÿ 22220 èíèöèàëèçèðóþ 0, ò.ê. ïðè çàïèñè â ðàçíûõ ÷àñòÿõ ïèëû ïîÿâëÿåòñÿ äèçáàëàíñ íàïðÿæåíèÿ.
    xpwm_time.saw_direct.all = 0;//0x0555;
    xpwm_time.one_or_two_interrupts_run = PWM_TWICE_INTERRUPT_RUN;
    
    initXpwmTimeStructure(&xpwm_time);
    init_alpha_pwm24(VAR_FREQ_PWM_XTICS);
/////////////////////////////////////////////////////////////

    svgen_pwm24_1.pwm_minimal_impuls_zero_minus = 0;//(float)DEF_PERIOD_MIN_MKS*1000.0*FREQ_INTERNAL_GENERATOR_XILINX_TMS/1000000000.0;//   DEF_PERIOD_MIN_XTICS_100;//DEF_PERIOD_MIN_XTICS_80;
    svgen_pwm24_1.pwm_minimal_impuls_zero_plus  = 0;//(float)DEF_PERIOD_MIN_MKS*1000.0*FREQ_INTERNAL_GENERATOR_XILINX_TMS/1000000000.0;// DEF_PERIOD_MIN_XTICS_80;

    svgen_pwm24_2.pwm_minimal_impuls_zero_minus = svgen_pwm24_1.pwm_minimal_impuls_zero_minus;
    svgen_pwm24_2.pwm_minimal_impuls_zero_plus  = svgen_pwm24_1.pwm_minimal_impuls_zero_plus;


    svgen_pwm24_1.Tclosed_high = xpwm_time.Tclosed_1;
    svgen_pwm24_2.Tclosed_high = xpwm_time.Tclosed_1;


    

    svgen_dq_1.Ualpha = 0;
    svgen_dq_1.Ubeta = 0;

    svgen_dq_2.Ualpha = 0;
    svgen_dq_2.Ubeta = 0;



}










// #pragma CODE_SECTION(recalc_time_pwm_minimal_2_xilinx_pwm24_l,".fast_run2");
void recalc_time_pwm_minimal_2_xilinx_pwm24_l(SVGEN_PWM24 *pwm24,
                                            _iq *T0, _iq *T1,
                                            _iq timpuls_corr )
{

//_iq pwm_t, timpuls_corr;

    volatile unsigned long pwm_t;
    volatile unsigned int minimal_plus, minimal_minus;



    minimal_plus = pwm24->pwm_minimal_impuls_zero_plus;
    minimal_minus = pwm24->pwm_minimal_impuls_zero_minus;

 //   if (pwm24->prev_level == V_PWM24_PREV_PWM_CLOSE || pwm24->prev_level == V_PWM24_PREV_PWM_MIDDLE || pwm24->prev_level == V_PWM24_PREV_PWM_WORK_KM0)
 //   {
 //       minimal_plus *= 2;
//        minimal_minus *= 2;
//    }

    pwm_t = timpuls_corr / pwm24->XilinxFreq;

 //   *T_imp =  pwm_t;

//    if (pwm_t>(pwm24->Tclosed_high-4*minimal_minus))
//        pwm_t=(pwm24->Tclosed_high-4*minimal_minus);


    if (timpuls_corr >= 0)
    {
        *T0 = pwm_t + minimal_plus;
        // *T1 = 0;
        *T1 = pwm24->Tclosed_high - minimal_minus;
    }
    else
    {
        *T0 = 0 + minimal_plus;
        // *T1 = -pwm_t - minimal_minus;
        *T1 = pwm24->Tclosed_high + pwm_t - minimal_minus;
    }


    // if (*T0 < minimal_plus)
    //     *T0 = minimal_plus;

    // if (*T0 > (pwm24->Tclosed_high - 2 * minimal_plus))
    //     *T0 = (pwm24->Tclosed_high - 2 * minimal_plus);

    // if (*T1 < (2 * minimal_minus))
    //     *T1 = 2 * minimal_minus;

    // if (*T1 > (pwm24->Tclosed_high - minimal_minus))
    //     *T1 = (pwm24->Tclosed_high - minimal_minus);

}

static DQ_TO_ALPHABETA dq_to_ab = DQ_TO_ALPHABETA_DEFAULTS;

// #pragma CODE_SECTION(test_calc_dq_pwm24,".v_24pwm_run");
void test_calc_dq_pwm24(_iq Ud, _iq Uq, _iq Ud2, _iq Uq2, _iq tetta,_iq Uzad_max,
_iq* maxUq1, _iq* maxUq2, _iq* Uq1Out, _iq* Uq2Out)
{
//	DQ_TO_ALPHABETA dq_to_ab = DQ_TO_ALPHABETA_DEFAULTS;
	//_iq maxUq = 0;

	*maxUq1 = 0;
	*maxUq2 = 0;

	_iq Uzad_max_square = _IQmpy(Uzad_max, Uzad_max);

	if (tetta > CONST_IQ_2PI)
	{
		tetta -= CONST_IQ_2PI;
	}
	
	if (tetta < 0)
	{
		tetta += CONST_IQ_2PI;
	}
	//Îãðàíè÷èë êîýôôèöèåíò ìîäóëÿöèè
    *maxUq1 = _IQsqrt(Uzad_max_square - _IQmpy(Ud, Ud));
    if (Uq > (*maxUq1)) { Uq = (*maxUq1);}
    if (Uq < -(*maxUq1)) { Uq = -(*maxUq1);}
	*Uq1Out = Uq;

	//Reculct dq to alpha-beta
	dq_to_ab.Tetta = tetta;
    dq_to_ab.Ud = Ud;
    dq_to_ab.Uq = Uq;
    dq_to_ab.calc2(&dq_to_ab);
	//Calc swgen times for 1-st winding
    svgen_dq_1.Ualpha = dq_to_ab.Ualpha;
    svgen_dq_1.Ubeta = dq_to_ab.Ubeta;
	svgen_dq_1.calc(&svgen_dq_1);

	//Îãðàíè÷èë êîýôôèöèåíò ìîäóëÿöèè
    *maxUq2 = _IQsqrt(Uzad_max_square - _IQmpy(Ud, Ud));
    if (Uq2 > *maxUq2) { Uq2 = *maxUq2;}
    if (Uq2 < -(*maxUq2)) { Uq2 = -(*maxUq2);}

*Uq2Out = Uq2;

	//Reculc dq to alpha-beta for 2-nd winding with winding displasement
	dq_to_ab.Tetta = tetta - winding_displacement;
    dq_to_ab.Ud = Ud2;
    dq_to_ab.Uq = Uq2;
    dq_to_ab.calc2(&dq_to_ab);
	//Calc swgen times for 1-st winding
	svgen_dq_2.Ualpha = dq_to_ab.Ualpha;
	svgen_dq_2.Ubeta = dq_to_ab.Ubeta;
	svgen_dq_2.calc(&svgen_dq_2);

	//1 winding
	recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_1, &svgen_pwm24_1.Ta_0.Ti, &svgen_pwm24_1.Ta_1.Ti,  svgen_dq_1.Ta);
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_1, &svgen_pwm24_1.Tb_0.Ti, &svgen_pwm24_1.Tb_1.Ti, svgen_dq_1.Tb);
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_1, &svgen_pwm24_1.Tc_0.Ti, &svgen_pwm24_1.Tc_1.Ti, svgen_dq_1.Tc);

    // 2 winding
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_2, &svgen_pwm24_2.Ta_0.Ti, &svgen_pwm24_2.Ta_1.Ti, svgen_dq_2.Ta);
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_2, &svgen_pwm24_2.Tb_0.Ti, &svgen_pwm24_2.Tb_1.Ti, svgen_dq_2.Tb);
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_2, &svgen_pwm24_2.Tc_0.Ti, &svgen_pwm24_2.Tc_1.Ti, svgen_dq_2.Tc);

//    set_predel_dshim24_simple0(&svgen_pwm24_1.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//    set_predel_dshim24_simple1(&svgen_pwm24_1.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//    set_predel_dshim24_simple0(&svgen_pwm24_1.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//    set_predel_dshim24_simple1(&svgen_pwm24_1.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//    set_predel_dshim24_simple0(&svgen_pwm24_1.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//    set_predel_dshim24_simple1(&svgen_pwm24_1.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//    set_predel_dshim24_simple0(&svgen_pwm24_2.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//    set_predel_dshim24_simple1(&svgen_pwm24_2.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//    set_predel_dshim24_simple0(&svgen_pwm24_2.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//    set_predel_dshim24_simple1(&svgen_pwm24_2.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//    set_predel_dshim24_simple0(&svgen_pwm24_2.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//    set_predel_dshim24_simple1(&svgen_pwm24_2.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
/*
    set_predel_dshim24(&svgen_pwm24_1.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_1.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_1.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);*/
}


// #pragma CODE_SECTION(test_calc_simple_dq_pwm24,".v_24pwm_run");
void test_calc_simple_dq_pwm24(_iq uz1, _iq uz2, _iq fz1, _iq fz2,_iq Uzad_max)
{
    static _iq hz_to_angle = _IQ(2.0 * PI * NORMA_FROTOR / FREQ_PWM / 2);
//	static _iq tetta = 0;
    DQ_TO_ALPHABETA dq_to_ab = DQ_TO_ALPHABETA_DEFAULTS;

    _iq Ud = 0;
    _iq Uq = _IQsat(uz1,Uzad_max,0);

	analog.tetta += _IQmpy(fz1, hz_to_angle);

	if (analog.tetta >= CONST_IQ_2PI)
	{
		analog.tetta -= CONST_IQ_2PI;
	}
	
	if (analog.tetta < 0)
	{
		analog.tetta += CONST_IQ_2PI;
	}

    dq_to_ab.Tetta = analog.tetta;
    dq_to_ab.Ud = Ud;
    dq_to_ab.Uq = Uq;
    dq_to_ab.calc2(&dq_to_ab);

    svgen_dq_1.Ualpha = dq_to_ab.Ualpha;
    svgen_dq_1.Ubeta = dq_to_ab.Ubeta;

//    svgen_dq_1.Ualpha = 0;
//    svgen_dq_1.Ubeta = 0;

    svgen_dq_1.calc(&svgen_dq_1);

    dq_to_ab.Tetta = analog.tetta - winding_displacement;
    dq_to_ab.Ud = Ud;
    dq_to_ab.Uq = Uq;
    dq_to_ab.calc2(&dq_to_ab);

    svgen_dq_2.Ualpha = dq_to_ab.Ualpha;
    svgen_dq_2.Ubeta = dq_to_ab.Ubeta;

    svgen_dq_2.calc(&svgen_dq_2);

    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_1, &svgen_pwm24_1.Ta_0.Ti, &svgen_pwm24_1.Ta_1.Ti,  svgen_dq_1.Ta);
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_1, &svgen_pwm24_1.Tb_0.Ti, &svgen_pwm24_1.Tb_1.Ti, svgen_dq_1.Tb);
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_1, &svgen_pwm24_1.Tc_0.Ti, &svgen_pwm24_1.Tc_1.Ti, svgen_dq_1.Tc);

    // 2
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_2, &svgen_pwm24_2.Ta_0.Ti, &svgen_pwm24_2.Ta_1.Ti, svgen_dq_2.Ta);
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_2, &svgen_pwm24_2.Tb_0.Ti, &svgen_pwm24_2.Tb_1.Ti, svgen_dq_2.Tb);
    recalc_time_pwm_minimal_2_xilinx_pwm24_l (&svgen_pwm24_2, &svgen_pwm24_2.Tc_0.Ti, &svgen_pwm24_2.Tc_1.Ti, svgen_dq_2.Tc);

//	logpar.log1 = (int16)(_IQtoIQ15(uz1));
//	logpar.log2 = (int16)(_IQtoIQ15(fz1));
//	logpar.log3 = (int16)(_IQtoIQ15(Ud));
//	logpar.log4 = (int16)(_IQtoIQ15(Uq));
//	logpar.log5 = (int16)(_IQtoIQ15(svgen_dq_1.Ualpha));
//	logpar.log6 = (int16)(_IQtoIQ15(svgen_dq_1.Ubeta));
//	logpar.log7 = (int16)(_IQtoIQ15(svgen_dq_1.Ta));
//	logpar.log8 = (int16)(_IQtoIQ15(svgen_dq_1.Tb));
//	logpar.log9 = (int16)(_IQtoIQ15(svgen_dq_1.Tc));
//	logpar.log10 = (int16)(_IQtoIQ12(analog.tetta));
//	logpar.log11 = (int16)(svgen_pwm24_1.Ta_0.Ti);
//	logpar.log12 = (int16)((svgen_pwm24_1.Ta_1.Ti));
//	logpar.log13 = (int16)(svgen_pwm24_1.Tb_0.Ti);
//	logpar.log14 = (int16)((svgen_pwm24_1.Tb_1.Ti));
//	logpar.log15 = (int16)(svgen_pwm24_1.Tc_0.Ti);
//	logpar.log16 = (int16)((svgen_pwm24_1.Tc_1.Ti));


//    svgen_pwm24_1.calc(&svgen_pwm24_1);
//    svgen_pwm24_2.calc(&svgen_pwm24_2);

    // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

    // !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

//	set_predel_dshim24_simple0(&svgen_pwm24_1.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//	set_predel_dshim24_simple1(&svgen_pwm24_1.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//	set_predel_dshim24_simple0(&svgen_pwm24_1.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//	set_predel_dshim24_simple1(&svgen_pwm24_1.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//	set_predel_dshim24_simple0(&svgen_pwm24_1.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//	set_predel_dshim24_simple1(&svgen_pwm24_1.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//	set_predel_dshim24_simple0(&svgen_pwm24_2.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//	set_predel_dshim24_simple1(&svgen_pwm24_2.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//	set_predel_dshim24_simple0(&svgen_pwm24_2.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//	set_predel_dshim24_simple1(&svgen_pwm24_2.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//
//	set_predel_dshim24_simple0(&svgen_pwm24_2.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
//	set_predel_dshim24_simple1(&svgen_pwm24_2.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

    set_predel_dshim24(&svgen_pwm24_1.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_1.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_1.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

}

// #pragma CODE_SECTION(test_calc_pwm24,".v_24pwm_run");
void test_calc_pwm24(_iq uz1, _iq uz2, _iq fz1)
{
	//static int i =0;
	svgen_pwm24_1.Freq = fz1;
	svgen_pwm24_2.Freq = fz1;
	
	svgen_pwm24_1.Gain = uz1;//_IQmpy(uz1,iq_koef_mod_korrect_1);
	svgen_pwm24_2.Gain = uz2;//_IQmpy(uz2,iq_koef_mod_korrect_2);
	
	svgen_pwm24_1.delta_U = filter.iqU_1_fast - filter.iqU_2_fast;
	svgen_pwm24_2.delta_U = filter.iqU_3_fast - filter.iqU_4_fast;
	
	// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
	svgen_pwm24_1.delta_U = 0;
	svgen_pwm24_2.delta_U = 0;
	// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

	svgen_pwm24_1.Ia = analog.iqIa1_1;
	svgen_pwm24_1.Ib = analog.iqIb1_1;
	svgen_pwm24_1.Ic = analog.iqIc1_1;

	svgen_pwm24_2.Ia = analog.iqIa2_1;
	svgen_pwm24_2.Ib = analog.iqIb2_1;
	svgen_pwm24_2.Ic = analog.iqIc2_1;

	svgen_pwm24_1.calc(&svgen_pwm24_1);
	svgen_pwm24_2.calc(&svgen_pwm24_2);

	// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
	
	// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

	set_predel_dshim24(&svgen_pwm24_1.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_1.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_1.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

//	if(((svgen_pwm24_2.Ta_0.Ti > (VAR_FREQ_PWM_XTICS - VAR_PERIOD_MIN_XTICS)) && (svgen_pwm24_2.Ta_0.Ti <= (VAR_FREQ_PWM_XTICS))) ||
//			((svgen_pwm24_2.Ta_1.Ti > (VAR_FREQ_PWM_XTICS - VAR_PERIOD_MIN_XTICS)) && (svgen_pwm24_2.Ta_1.Ti <= (VAR_FREQ_PWM_XTICS))) ||
//			((svgen_pwm24_2.Tb_0.Ti > (VAR_FREQ_PWM_XTICS - VAR_PERIOD_MIN_XTICS)) && (svgen_pwm24_2.Tb_0.Ti <= (VAR_FREQ_PWM_XTICS))) ||
//			((svgen_pwm24_2.Tb_1.Ti > (VAR_FREQ_PWM_XTICS - VAR_PERIOD_MIN_XTICS)) && (svgen_pwm24_2.Tb_1.Ti <= (VAR_FREQ_PWM_XTICS))) ||
//			((svgen_pwm24_2.Tc_0.Ti > (VAR_FREQ_PWM_XTICS - VAR_PERIOD_MIN_XTICS)) && (svgen_pwm24_2.Tc_0.Ti <= (VAR_FREQ_PWM_XTICS))) ||
//			((svgen_pwm24_2.Tc_1.Ti > (VAR_FREQ_PWM_XTICS - VAR_PERIOD_MIN_XTICS)) && (svgen_pwm24_2.Tc_1.Ti <= (VAR_FREQ_PWM_XTICS))))
//	{
//		asm(" NOP ");
//	}
//
//	if( ((svgen_pwm24_2.Ta_0.Ti > 0) && (svgen_pwm24_2.Ta_0.Ti < (VAR_PERIOD_MIN_XTICS))) ||
//		((svgen_pwm24_2.Ta_1.Ti > 0) && (svgen_pwm24_2.Ta_1.Ti < (VAR_PERIOD_MIN_XTICS))) ||
//		((svgen_pwm24_2.Tb_0.Ti > 0) && (svgen_pwm24_2.Tb_0.Ti < (VAR_PERIOD_MIN_XTICS))) ||
//		((svgen_pwm24_2.Tb_1.Ti > 0) && (svgen_pwm24_2.Tb_1.Ti < (VAR_PERIOD_MIN_XTICS))) ||
//		((svgen_pwm24_2.Tc_0.Ti > 0) && (svgen_pwm24_2.Tc_0.Ti < (VAR_PERIOD_MIN_XTICS))) ||
//		((svgen_pwm24_2.Tc_1.Ti > 0) && (svgen_pwm24_2.Tc_1.Ti < (VAR_PERIOD_MIN_XTICS))))
//	{
//		asm(" NOP ");
//	}
}


// #pragma CODE_SECTION(svgen_pwm24_calc,".v_24pwm_run");
void svgen_pwm24_calc(SVGEN_PWM24 *vt)
{
	_iq StepAngle;
	
	StepAngle = _IQmpy(vt->Freq,vt->FreqMax);
	
	vt->Alpha = vt->Alpha + StepAngle;
	
	
	if (vt->Alpha > CONST_IQ_2PI)
	{
		vt->Alpha -= CONST_IQ_2PI;
	}
	
	if (vt->Alpha < 0)
	{
		vt->Alpha += CONST_IQ_2PI;
	}


	calc_time_one_tk(vt->Gain, vt->Alpha, vt->delta_U,  vt->Ia,  vt->Ib, vt->Ic,
					 vt->number_svgen, &vt->Ta_0, &vt->Ta_1,&vt->Tb_0, &vt->Tb_1,&vt->Tc_0, &vt->Tc_1);



	vt->Ta_0.Ti = vt->Ta_0.Ti/vt->XilinxFreq;
	vt->Ta_1.Ti = vt->Ta_1.Ti/vt->XilinxFreq;
	
	vt->Tb_0.Ti = vt->Tb_0.Ti/vt->XilinxFreq;
	vt->Tb_1.Ti = vt->Tb_1.Ti/vt->XilinxFreq;
	
	vt->Tc_0.Ti = vt->Tc_0.Ti/vt->XilinxFreq;
	vt->Tc_1.Ti = vt->Tc_1.Ti/vt->XilinxFreq;
	
}


// #pragma CODE_SECTION(calc_time_one_tk,".v_24pwm_run");
void calc_time_one_tk(_iq gain, _iq teta, _iq delta_U,
					  _iq Ia, _iq Ib, _iq Ic,
					  unsigned int number, 
					  SVGEN_PWM24_TIME *tk0, 
					  SVGEN_PWM24_TIME *tk1,
					  SVGEN_PWM24_TIME *tk2, 
					  SVGEN_PWM24_TIME *tk3,
					  SVGEN_PWM24_TIME *tk4, 
					  SVGEN_PWM24_TIME *tk5)
{
	_iq iq_t0 = 0, iq_t1 = 0, iq_t2 = 0, iq_t3 = 0, iq_t4 = 0, iq_t5 = 0;
	_iq t_pos = 0, t_neg = 0;
	_iq delta_ttt;
	_iq teta60;
	
	int sector, region;
	int cur_sign, i, ki;
	int updown_tk0;
	int updown_tk1;

	volatile _iq t_tk0, t_tk1;
	
	updown_tk0 = 1;
	updown_tk1 = 0;
	
	sector = detect_sec(teta);	//
	teta60 = teta - _IQmpy(_IQ(sector - 1),CONST_IQ_PI3);	//
	
	if ((sector == 2) || (sector == 4) || (sector == 6))
	{
		teta60 = CONST_IQ_PI3 - teta60;
	}
	
	region = detect_region(gain, teta60); //
	
	calc_t_abc(gain, teta60, region, &iq_t0, &iq_t1, &iq_t2, &iq_t3, &iq_t4, &iq_t5);
	

	delta_ttt = 0; //calc_delta_t(delta_U,number,region);
	//delta_ttt = 0;

	//if (number == 1)
	//{
		//logpar.log1 = (int16)(_IQtoIQ15(delta_U));
		//logpar.log2 = (int16)(_IQtoIQ15(delta_ttt));
	//}
	//else
	//{
		//logpar.log3 = (int16)(_IQtoIQ15(delta_U));
		//logpar.log4 = (int16)(_IQtoIQ15(delta_ttt));
	//}
	
	calc_arr_tph(sector, region, iq_t0, iq_t1, iq_t2, iq_t3, iq_t4, iq_t5, delta_ttt,number, Ia, Ib, Ic);

	for (ki = 0; ki < 3; ki++)
	{
		t_pos = 0;
		t_neg = 0;
		
		for (i = 0; i < 7; i++)
		{
			cur_sign = ar_sa_all[ki][sector - 1][region - 1][i];
			
	 		if (cur_sign > 0)
	 		{
	 			t_pos += ar_tph[i];
			}

	 		if (cur_sign < 0)
	 		{
	 			t_neg += ar_tph[i];
			}
	 	}

		t_pos = t_pos << 1;
   
   		t_neg = t_neg << 1;

		if (t_neg == 0)
		{
			t_tk0 = 0;
		}
		else
		{
			t_tk0 = t_neg;
		}
	  
		if (t_pos == 0)
	 	{
	 		t_tk1 = CONST_IQ_1;
		}
		else
		{
	   		t_tk1 = CONST_IQ_1 - t_pos;
	   	}

		switch (ki)
		{
			case 0:
				tk0->up_or_down = updown_tk0;
				tk0->Ti = t_tk0;
				
				tk1->up_or_down = updown_tk1;
				tk1->Ti = t_tk1;

				break;
				
			case 1:
				tk2->up_or_down = updown_tk0;
				tk2->Ti = t_tk0;
				
				tk3->up_or_down = updown_tk1;
				tk3->Ti = t_tk1;

				break;
				
			case 2:
				tk4->up_or_down = updown_tk0;
				tk4->Ti = t_tk0;
				
				tk5->up_or_down = updown_tk1;
				tk5->Ti = t_tk1;

				break;
				
			default: break;
		}
	}
}




// #pragma CODE_SECTION(detect_region,".v_24pwm_run");
int detect_region(_iq k, _iq teta)
{
  volatile _iq x,y;
  volatile int reg=0;
   
  x = _IQmpy(k,_IQcos(teta));
  y = _IQmpy(k,_IQsin(teta));

  if (y>=CONST_IQ_05) reg=4;
	else if (y < (CONST_IQ_1 - _IQmpy(x,SQRT3))) reg = 1;
		else if (y < (_IQmpy(x,SQRT3) - CONST_IQ_1)) reg = 2;
			else reg = 3;

  return reg;
}




// #pragma CODE_SECTION(detect_sec,".v_24pwm_run");
int detect_sec(_iq teta)
{
	volatile _iq sector;
	volatile int sectorint;
	
	sector = _IQdiv(teta,CONST_IQ_PI3);
	sectorint = (sector >> 24) + 1;
	
	if (sectorint > 6) sectorint-=6;
	
	return sectorint;
}


#define nSIN_t(k,t)  _IQmpy(k,_IQsin(t))

#define nSIN_p3pt(k,t)  _IQmpy(k,_IQsin(CONST_IQ_PI3+t))

#define nSIN_p3mt(k,t)  _IQmpy(k,_IQsin(CONST_IQ_PI3-t))

#define nSIN_tmp3(k,t)  _IQmpy(k,_IQsin(t-CONST_IQ_PI3))

//k - (Uzad)
//teta -
//region - 
/*
 * iq_tt0 - time of vectors op, oo, on
 * iq_tt1 - time of vectors ap, an
 * iq_tt2 - time of vectors bp, bn
 * iq_tt3 - time of vector c
 * iq_tt4 - time of vector a
 * iq_tt5 - time of vector b
 */
// #pragma CODE_SECTION(calc_t_abc,".v_24pwm_run");
void calc_t_abc(_iq k, _iq teta, int region, _iq *iq_tt0, _iq *iq_tt1, _iq *iq_tt2, _iq *iq_tt3, _iq *iq_tt4, _iq *iq_tt5)
{
	switch(region)
	{
		case 1 :
			*iq_tt0 = CONST_IQ_05 - nSIN_p3pt(k,teta);
			*iq_tt1 = nSIN_p3mt(k,teta);
			*iq_tt2 = nSIN_t(k,teta);
			*iq_tt3 = 0;
			*iq_tt4 = 0;
			*iq_tt5 = 0;
			break;

		case 2 :
			*iq_tt0 = 0;
			*iq_tt1 = CONST_IQ_1 - nSIN_p3pt(k,teta);
			*iq_tt2 = 0;
			*iq_tt3 = nSIN_t(k,teta);
			*iq_tt4 = nSIN_p3mt(k,teta) - CONST_IQ_05;
			*iq_tt5 = 0;
			break;

		case 3 :
			*iq_tt0 = 0;
			*iq_tt1 = CONST_IQ_05 - nSIN_t(k,teta);
			*iq_tt2 = CONST_IQ_05 - nSIN_p3mt(k,teta);
			*iq_tt3 = nSIN_p3pt(k,teta) - CONST_IQ_05;
			*iq_tt4 = 0;
			*iq_tt5 = 0;
			break;

		case 4 :
			*iq_tt0 = 0;
			*iq_tt1 = 0;
			*iq_tt2 = CONST_IQ_1 - nSIN_p3pt(k,teta);
			*iq_tt3 = nSIN_p3mt(k,teta);
			*iq_tt4 = 0;
			*iq_tt5 = nSIN_t(k,teta) - CONST_IQ_05;
			break;

		default :
			*iq_tt0 = 0;
			*iq_tt1 = 0;
			*iq_tt2 = 0;
			*iq_tt3 = 0;
			*iq_tt4 = 0;
			*iq_tt5 = 0;
			break;
	}

    return;
} 

//sector 
//region 
//iq_ttt0 - iq_ttt5 - times from calc_t_abs
//delta_t - 
//number_sv - 
//iqIa, iqIb, iqIc 
// #pragma CODE_SECTION(calc_arr_tph, ".v_24pwm_run");
void calc_arr_tph(int sector,int region, _iq iq_ttt0, _iq iq_ttt1, _iq iq_ttt2, _iq iq_ttt3, _iq iq_ttt4,
				  _iq iq_ttt5, _iq delta_t, unsigned int number_sv,
				  _iq iqIa, _iq iqIb, _iq iqIc)
{
	_iq iq_var1 = 0;
	_iq iqIx, iqIy, iqIz;
	_iq iq_alfa_1_p = CONST_IQ_05, iq_alfa_1_n = CONST_IQ_05, iq_alfa_2_n = CONST_IQ_05, iq_alfa_2_p = CONST_IQ_05;
	_iq iq_alfa = 0;
//	_iq iqIa, iqIb, iqIc;
	_iq iq_mpy1 = 0;
	_iq iq_mpy3 = 0;
	_iq summ = 0;
	

  	switch (sector)
  	{
		case 1:
				iqIx = iqIc;
				iqIy = iqIa;
				iqIz = iqIb;
		
				break;
		case 2:

				iqIx = iqIb;
				iqIy = iqIa;
				iqIz = iqIc;

				break;
		case 3:

				iqIx = iqIb;
				iqIy = iqIc;
				iqIz = iqIa;

				break;
		case 4:

				iqIx = iqIa;
				iqIy = iqIc;
				iqIz = iqIb;

				break;
		case 5:

				iqIx = iqIa;
				iqIy = iqIb;
				iqIz = iqIc;

				break;
		case 6:

				iqIx = iqIc;
				iqIy = iqIb;
				iqIz = iqIa;

				break;
		default:

				iqIx = 0;
				iqIy = 0;
				iqIz = 0;

				break;
	}

	if (region == 1)
	{
//		if (delta_t != 0)	//ðàçáàëàíñ íàïðÿæåíèé	//îòêëþ÷åíî òåñòèðîâàòü
//		{
//			iq_alfa = _IQsat((CONST_IQ_05 - _IQmpy(delta_t,IQ_KP_DELTA_T)),IQ_ALFA_SATURATION1,IQ_ALFA_SATURATION2);

			//if (delta_t < 0)
			//{
				//iq_alfa = IQ_ALFA_SATURATION1;
			//}
			//else
			//{
				//iq_alfa = IQ_ALFA_SATURATION2;
			//}
//		}
//		else
		{
			iq_alfa = CONST_IQ_05;
		}
	}
	else
	{
		iq_mpy1 = _IQmpy(_IQabs(iqIx),iq_ttt1)+_IQmpy(_IQabs(iqIy),iq_ttt2);
		iq_mpy3 = _IQmpy(iqIz,iq_ttt3);

		summ = _IQdiv((iq_mpy3),(iq_mpy1));

		//iq_alfa = _IQsat((_IQmpy(CONST_IQ_05,(CONST_IQ_1 + summ)) - _IQmpy(delta_t,IQ_KP_DELTA_T)),IQ_ALFA_SATURATION1,IQ_ALFA_SATURATION2);
		iq_alfa = CONST_IQ_05;	//test
	}

			
	if (iqIx >= 0)
	{
		iq_alfa_1_p = iq_alfa;
		iq_alfa_1_n = CONST_IQ_1 - iq_alfa;
	}
	else
	{
		iq_alfa_1_p = CONST_IQ_1 - iq_alfa;
		iq_alfa_1_n = iq_alfa;
	}

	if (iqIy >= 0)
	{
		iq_alfa_2_p = CONST_IQ_1 - iq_alfa;
		iq_alfa_2_n = iq_alfa;
	}
	else
	{
		iq_alfa_2_p = iq_alfa;
		iq_alfa_2_n = CONST_IQ_1 - iq_alfa;
	}
			
		
	//if (number_sv == 2)
	//{
		//logpar.log1 = (int16)(sector);
		//logpar.log2 = (int16)(region);
		//logpar.log3 = (int16)(_IQtoIQ15(iq_alfa));
		//logpar.log4 = (int16)(_IQtoIQ15(iq_alfa_1_p));
		//logpar.log5 = (int16)(_IQtoIQ15(iq_alfa_2_p));
		//logpar.log6 = (int16)(_IQtoIQ13(summ));
		//logpar.log3 = (int16)(_IQtoIQ14(iq_ttt0));
		//logpar.log4 = (int16)(_IQtoIQ14(iq_ttt1));
		//logpar.log5 = (int16)(_IQtoIQ14(iq_ttt2));
		//logpar.log6 = (int16)(_IQtoIQ14(iq_ttt3));
		//logpar.log7 = (int16)(_IQtoIQ14(iq_ttt4));
		//logpar.log8 = (int16)(_IQtoIQ14(iq_ttt5));
		//logpar.log10 = (int16)(_IQtoIQ15(delta_t1_struct.Up));
		//logpar.log11 = (int16)(_IQtoIQ15(delta_t1_struct.Ui));
		//logpar.log12 = (int16)(_IQtoIQ15(delta_t1_struct.Ud));
		//logpar.log13 = (int16)(_IQtoIQ15(iqIx));
		//logpar.log14 = (int16)(_IQtoIQ15(iqIy));
		//logpar.log15 = (int16)(_IQtoIQ15(iqIz));

		//logpar.log12 = (int16)(_IQtoIQ15(_IQmpy(iq_alfa_2_p,iq_ttt2)));
		//logpar.log13 = (int16)(_IQtoIQ15(_IQmpy(iq_alfa_2_n,iq_ttt2)));
		//logpar.log14 = (int16)(_IQtoIQ15(delta_t));
	//}
	//else
			//logpar.log15 = (int16)(_IQtoIQ15(delta_t));
	
//	if (region == 1)
//	{
//		if (f.Rele3 == 1)
//		{
//			iq_alfa_1_p = CONST_IQ_05;
//			iq_alfa_2_p = CONST_IQ_05;
//			iq_alfa_1_n = CONST_IQ_05;
//			iq_alfa_2_n = CONST_IQ_05;
//		}
//	}
//	else
//	{
//		if (f.Down50 == 1)
//		{
//			iq_alfa_1_p = CONST_IQ_05;
//			iq_alfa_2_p = CONST_IQ_05;
//			iq_alfa_1_n = CONST_IQ_05;
//			iq_alfa_2_n = CONST_IQ_05;
//		}
//	}

	switch (region)
	{
		case 1: 
				iq_var1 = _IQdiv(iq_ttt0,CONST_IQ_3);

				ar_tph[0] = iq_var1;
				ar_tph[1] = _IQmpy(iq_alfa_1_n,iq_ttt1);
				ar_tph[2] = _IQmpy(iq_alfa_2_n,iq_ttt2);
				ar_tph[3] = iq_var1;
				ar_tph[4] = _IQmpy(iq_alfa_1_p,iq_ttt1);
				ar_tph[5] = _IQmpy(iq_alfa_2_p,iq_ttt2);
				ar_tph[6] = iq_var1;
				break;

		case 2:
				ar_tph[0] = _IQmpy(iq_alfa_1_n,iq_ttt1);
				ar_tph[1] = iq_ttt4;
				ar_tph[2] = iq_ttt3;
				ar_tph[3] = _IQmpy(iq_alfa_1_p,iq_ttt1);
				ar_tph[4] = 0;
				ar_tph[5] = 0;
				ar_tph[6] = 0;											
				break;

		case 3: 
				ar_tph[0] = _IQmpy(iq_alfa_1_n,iq_ttt1);
				ar_tph[1] = _IQmpy(iq_alfa_2_n,iq_ttt2);
				ar_tph[2] = iq_ttt3;
				ar_tph[3] = _IQmpy(iq_alfa_1_p,iq_ttt1);
				ar_tph[4] = _IQmpy(iq_alfa_2_p,iq_ttt2);
				ar_tph[5] = 0;
				ar_tph[6] = 0;											
				break;

		case 4: 
				ar_tph[0] = _IQmpy(iq_alfa_2_n,iq_ttt2);
				ar_tph[1] = iq_ttt3;
				ar_tph[2] = iq_ttt5;
				ar_tph[3] = _IQmpy(iq_alfa_2_p,iq_ttt2);
				ar_tph[4] = 0;
				ar_tph[5] = 0;
				ar_tph[6] = 0;
				break;

		default :
				break;
	}


}

/*
 // Function is commented because of in project 222220 should not be large voltage diviation
// #pragma CODE_SECTION(calc_delta_t,".v_24pwm_run");
_iq calc_delta_t(_iq delta_1, unsigned int number,int region)
{
	if(_IQabs(delta_1) > MAX_LEVEL_DELTA_T)
	{
		// Îøèáêà ðàçáàëàíñà          ConvErrors.m2.bit.Razbalans |= 1;
		return 0;
	}
	
	if (number == 1)
	{
		delta_t1_struct.Fdb = delta_1;
		delta_t1_struct.calc(&delta_t1_struct);
		
		if (_IQabs(delta_t1_struct.Out) <= INSENSITIVE_LEVEL_DELTA_T) return 0;
		else return delta_t1_struct.Out;
	}
	else
	{
		delta_t2_struct.Fdb = delta_1;
		delta_t2_struct.calc(&delta_t2_struct);
		
		if (_IQabs(delta_t2_struct.Out) <= INSENSITIVE_LEVEL_DELTA_T) return 0;
		else return delta_t2_struct.Out;
	}
}

*/
//#pragma CODE_SECTION(set_predel_dshim24,".fast_run2");

// #pragma CODE_SECTION(set_predel_dshim24_simple0,".v_24pwm_run");
void set_predel_dshim24_simple0(SVGEN_PWM24_TIME *T,int16 dmin,int16 dmax)
{
    dmax++; //Íàäî çàäàòü çíà÷åíèå áîëüøå, ÷åì ìàêñ çíà÷åíèå ïèëû, ÷òîáû íåáûëî ïåðåñå÷åíèé
    if (T->Ti < dmin)
    {
        if (T->Ti < dmin/2)
         T->Ti = 0;
        else
         T->Ti = dmin;

    } else if (T->Ti >= (dmax - dmin)) {
        T->Ti = (dmax - dmin);
    }
}
// #pragma CODE_SECTION(set_predel_dshim24_simple1,".v_24pwm_run");
void set_predel_dshim24_simple1(SVGEN_PWM24_TIME *T,int16 dmin,int16 dmax)
{
    dmax++; //Íàäî çàäàòü çíà÷åíèå áîëüøå, ÷åì ìàêñ çíà÷åíèå ïèëû, ÷òîáû íåáûëî ïåðåñå÷åíèé
    if (T->Ti >= (dmax - dmin))
    {
        if (T->Ti >= (dmax - dmin/2))
            T->Ti = dmax;
        else
            T->Ti = dmax-dmin;
//        T->Ti = dmax;
    } else if (T->Ti <= dmin) {
        T->Ti = dmin;
    }
}


// #pragma CODE_SECTION(set_predel_dshim24,".v_24pwm_run");
void set_predel_dshim24(SVGEN_PWM24_TIME *T,int16 dmin,int16 dmax)
{
	//static unsigned int counter_pass = 0;
	//static unsigned int summ = 0;
	//int16 dshim24 = 0;
	dmax++;	//Íàäî çàäàòü çíà÷åíèå áîëüøå, ÷åì ìàêñ çíà÷åíèå ïèëû, ÷òîáû íåáûëî ïåðåñå÷åíèé
	if (T->Ti < dmin)
	{
		T->impuls_lenght_max = 0;
		T->counter_pass_max = 0;
		
		T->impuls_lenght_min = T->impuls_lenght_min + T->Ti;
		T->counter_pass_min++;
		
		if (T->counter_pass_min <= 3)
		{
			if (T->impuls_lenght_min <= dmin)
			{
				T->Ti = 0;
			}
			else
			{
//				T->Ti = dmin; //T->impuls_lenght_min;
//				T->impuls_lenght_min -= dmin;// = 0;
				T->Ti = T->impuls_lenght_min;
				T->impuls_lenght_min = 0;
				T->counter_pass_min = 0;
//				if (T->impuls_lenght_min < 0) {
//				    T->counter_pass_min = 0;
//				    T->impuls_lenght_min = 0;
//				} else {
//				    T->counter_pass_min -= 1;
//				}
			}
	   	}
		else
		{
			T->counter_pass_min = 1;
			T->impuls_lenght_min = T->Ti;
			T->Ti = 0;
		}
	}
	else
	{
		T->impuls_lenght_min = 0;
		T->counter_pass_min = 0;

//		if (T->Ti > (dmax - dmin))
//	   	{
//			dshim = dmax;
//		}
//		else
//		{
//			dshim = T->Ti;
//		}

		if (T->Ti >= (dmax - dmin))
		{
			T->impuls_lenght_max = T->impuls_lenght_max + (dmax - T->Ti - 1);
			T->counter_pass_max++;

			if (T->counter_pass_max <= 3)
			{
				if (T->impuls_lenght_max <= dmin)
				{
					T->Ti = dmax;
				}
				else
				{
//					T->Ti = dmax - dmin; //T->impuls_lenght_max;
//					T->impuls_lenght_max -= dmin;// = 0;
					T->Ti = dmax - T->impuls_lenght_max;
					T->impuls_lenght_max = 0;
					T->counter_pass_max = 0;
//					if (T->impuls_lenght_max < 0) {
//					    T->impuls_lenght_max = 0;
//					    T->counter_pass_max = 0;
//					} else {
//					    T->counter_pass_max -= 1;
//					}
				}
		   	}
			else
	   		{
				T->counter_pass_max = 1;
				T->impuls_lenght_max = dmax - T->Ti;
				T->Ti = dmax;
			}
		}
		else
		{	
			T->counter_pass_max = 0;
			T->impuls_lenght_max = 0;
		}
	}
	
	//return dshim24;
}



void init_alpha_pwm24(int xFreq)
{
	xFreq = xFreq + 1;

	svgen_pwm24_1.number_svgen = 1;
	svgen_pwm24_2.number_svgen = 2;

	//pidCur_Kp = _IQ(PID_KP_DELTA_KOMP_I);
	//pidCur_Ki = _IQ(PID_KI_DELTA_KOMP_I);

//	svgen_pwm24_1.prev_level = V_PWM24_PREV_PWM_CLOSE;
	svgen_pwm24_1.saw_direct.all = xpwm_time.saw_direct.all & 0x3f;
	svgen_pwm24_1.Tclosed_saw_direct_0 = xpwm_time.Tclosed_saw_direct_0;//  xpwm_time.Tclosed_high;//var_freq_pwm_xtics + 1;
	svgen_pwm24_1.Tclosed_saw_direct_1 = xpwm_time.Tclosed_saw_direct_1;
	svgen_pwm24_1.Tclosed_high = xpwm_time.Tclosed_high;

//	svgen_pwm24_2.prev_level = V_PWM24_PREV_PWM_CLOSE;
	svgen_pwm24_2.saw_direct.all = (xpwm_time.saw_direct.all >> 6) & 0x3f;
	svgen_pwm24_2.Tclosed_saw_direct_0 = xpwm_time.Tclosed_saw_direct_0;//  xpwm_time.Tclosed_high;//var_freq_pwm_xtics + 1;
	svgen_pwm24_2.Tclosed_saw_direct_1 = xpwm_time.Tclosed_saw_direct_1;
	svgen_pwm24_2.Tclosed_high = xpwm_time.Tclosed_high;
	
	svgen_pwm24_1.FreqMax = _IQ(2.0*PI*F_STATOR_MAX/FREQ_PWM/2);//Äîïïîëíèòåëüíîå äåëåíèå íà 2, ò.ê. 2 ðàçà çàõîäèò â ïðåðûâàíèå çà ïåðèîä øèì
 	svgen_pwm24_2.FreqMax = _IQ(2.0*PI*F_STATOR_MAX/FREQ_PWM/2);
 	
 	svgen_pwm24_1.XilinxFreq = CONST_IQ_1/xFreq;
	svgen_pwm24_2.XilinxFreq = CONST_IQ_1/xFreq;
	
	// 30 
    svgen_pwm24_1.Alpha = 0;	//winding_displacement;
	svgen_pwm24_2.Alpha = -winding_displacement;

	svgen_pwm24_1.delta_t = 0;
	svgen_pwm24_2.delta_t = 0;
}

/*
void init_freq_array(void)
{
	unsigned int i = 0;
	//unsigned int j = 0;
	int var1 = 0;

	var1 = 32767 / (FREQ_PWM_MAX - FREQ_PWM_MIN);

	for (i = 0; i < COUNT_VAR_FREQ; i++)
	{
		//j = rand() / 1023;
		//freq_array[i] = array_optim_freq[j];
		//do
			freq_array[i] = FREQ_PWM_MIN + (rand() / var1);
		//while ((freq_array[i] < 945) && (freq_array[i] > 930));
	}

	//freq_array[0] = 991;
	//freq_array[1] = 1430;
}
*/


//#pragma CODE_SECTION(calc_freq_pwm,".v_24pwm_run");
//#pragma CODE_SECTION(calc_freq_pwm,".fast_run");
/*void calc_freq_pwm()
{
	static int prev_freq_pwm = 0;
	static float pwm_period = 0;
	static float var0 = 0;
	//static int line = 0;
	//static int i = 0;
	static unsigned int proc_ticks = 1;
	int var1 = 0;
	//static int i = 0;

	if ((f.flag_change_pwm_freq == 1) && (f.flag_random_freq == 1))
	{	
		if (proc_ticks >= 1)
		{
			proc_ticks = 0;
			
			
			if (line == 0)
			{
				VAR_FREQ_PWM_HZ = VAR_FREQ_PWM_HZ + 1;
				if (VAR_FREQ_PWM_HZ > FREQ_PWM_MAX)
				{
					VAR_FREQ_PWM_HZ = FREQ_PWM_MAX;
					line = 1;
				}
			}
			else
			{	
				VAR_FREQ_PWM_HZ = VAR_FREQ_PWM_HZ - 1;
				if (VAR_FREQ_PWM_HZ < FREQ_PWM)
				{
					VAR_FREQ_PWM_HZ = FREQ_PWM;
					line = 0;
				}
			}
			



			// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
			//VAR_FREQ_PWM_HZ = freq_array[i];
			//i_led2_on_off(1);

			var1 = 32767 / (freq_pwm_max_hz - freq_pwm_min_hz);
			VAR_FREQ_PWM_HZ = freq_pwm_min_hz + (rand() / var1);

			//i_led2_on_off(0);
			// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

			if (VAR_FREQ_PWM_HZ > freq_pwm_max_hz)
			{
				VAR_FREQ_PWM_HZ = freq_pwm_max_hz;
			}
			else
			{
				if (VAR_FREQ_PWM_HZ < freq_pwm_min_hz)
				{
					VAR_FREQ_PWM_HZ = freq_pwm_min_hz;
				}
			}
			//i++;

			//if (i >= COUNT_VAR_FREQ)
			//{
				//i = 0;
			//}
			
		}
		
		// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
		//if (VAR_FREQ_PWM_HZ == FREQ_PWM_MIN)
		//{
			//VAR_FREQ_PWM_HZ = FREQ_PWM_MAX;
		//}
		//else
		//{
			//VAR_FREQ_PWM_HZ = FREQ_PWM_MIN;
		//}

		//if (f.Rele1 == 1)
		//{
			//if (i == 0)
			//{
				//VAR_FREQ_PWM_HZ = 1192;;
				//i = 1;
			//}
			//else
			//{
				//VAR_FREQ_PWM_HZ = 792;
			//}
		//}
		//else
		//{
			//i = 0;
			//VAR_FREQ_PWM_HZ = 1192;
		//}
		// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
	}
	//else
	//{
		//VAR_FREQ_PWM_HZ = FREQ_PWM;
	//}

	
	if (prev_freq_pwm != VAR_FREQ_PWM_HZ)
	{
		prev_freq_pwm = VAR_FREQ_PWM_HZ;
		FREQ_MAX = _IQ(2.0*PI*F_STATOR_MAX/VAR_FREQ_PWM_HZ);
	
		var0 = (float)VAR_FREQ_PWM_HZ;
		//pwm_period = ((float64)HSPCLK) / ((float64)VAR_FREQ_PWM_HZ);
	
		pwm_period = HSPCLK / var0;
		
		pwm_period = pwm_period / 2.0;
	
		FREQ_PWM_XTICS = ((int) pwm_period) >> 3;
		
		XILINX_FREQ = 16777216/(FREQ_PWM_XTICS + 1);

		FLAG_CHANGE_FREQ_PWM = 1;
	}

	proc_ticks++;
}
*/

void change_freq_pwm(_iq xFreq) {
	svgen_pwm24_1.FreqMax = _IQ(2.0*PI*F_STATOR_MAX/3750000 / xFreq / 2 /2);//Äîïïîëíèòåëüíîå äåëåíèå íà 2, ò.ê. 2 ðàçà çàõîäèò â ïðåðûâàíèå çà ïåðèîä øèì
	svgen_pwm24_2.FreqMax = _IQ(2.0*PI*F_STATOR_MAX/ 3750000 / xFreq / 2 /2);

	xFreq += 1;
	svgen_pwm24_1.XilinxFreq = CONST_IQ_1/xFreq;
	svgen_pwm24_2.XilinxFreq = CONST_IQ_1/xFreq;
}

// #pragma CODE_SECTION(test_calc_pwm24_dq,".v_24pwm_run");
void test_calc_pwm24_dq(_iq U_zad1, _iq U_zad2,_iq teta)
{
	svgen_pwm24_1.Freq = 0;
	svgen_pwm24_2.Freq = 0;
	
	svgen_pwm24_1.Gain = U_zad1;
	svgen_pwm24_2.Gain = U_zad2;

	svgen_pwm24_1.Alpha = teta;
	svgen_pwm24_2.Alpha = teta - winding_displacement;
	
	svgen_pwm24_1.delta_U = filter.iqU_1_fast - filter.iqU_2_fast;
	svgen_pwm24_2.delta_U = filter.iqU_3_fast - filter.iqU_4_fast;
	
	// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
	svgen_pwm24_1.delta_U = 0;
	svgen_pwm24_2.delta_U = 0;
	// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

	svgen_pwm24_1.Ia = analog.iqIa1_1;
	svgen_pwm24_1.Ib = analog.iqIb1_1;
	svgen_pwm24_1.Ic = analog.iqIc1_1;

	svgen_pwm24_2.Ia = analog.iqIa2_1;
	svgen_pwm24_2.Ib = analog.iqIb2_1;
	svgen_pwm24_2.Ic = analog.iqIc2_1;

	svgen_pwm24_1.calc_dq(&svgen_pwm24_1);
	svgen_pwm24_2.calc_dq(&svgen_pwm24_2);

	
	// !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

	set_predel_dshim24(&svgen_pwm24_1.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	
	set_predel_dshim24(&svgen_pwm24_1.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	
	set_predel_dshim24(&svgen_pwm24_1.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_1.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Ta_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Ta_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Tb_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Tb_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);

	set_predel_dshim24(&svgen_pwm24_2.Tc_0,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);
	set_predel_dshim24(&svgen_pwm24_2.Tc_1,VAR_PERIOD_MIN_XTICS,VAR_FREQ_PWM_XTICS);


}


// #pragma CODE_SECTION(svgen_pwm24_calc,".v_24pwm_run");
void svgen_pwm24_calc_dq(SVGEN_PWM24 *vt)
{
	
	if (vt->Alpha > CONST_IQ_2PI)
	{
		vt->Alpha -= CONST_IQ_2PI;
	}
	
	if (vt->Alpha < 0)
	{
		vt->Alpha += CONST_IQ_2PI;
	}


	calc_time_one_tk(vt->Gain, vt->Alpha, vt->delta_U,  vt->Ia,  vt->Ib, vt->Ic,
					 vt->number_svgen, &vt->Ta_0, &vt->Ta_1,&vt->Tb_0, &vt->Tb_1,&vt->Tc_0, &vt->Tc_1);
	
	
	vt->Ta_0.Ti = vt->Ta_0.Ti/vt->XilinxFreq;
	vt->Ta_1.Ti = vt->Ta_1.Ti/vt->XilinxFreq;
	
	vt->Tb_0.Ti = vt->Tb_0.Ti/vt->XilinxFreq;
	vt->Tb_1.Ti = vt->Tb_1.Ti/vt->XilinxFreq;
	
	vt->Tc_0.Ti = vt->Tc_0.Ti/vt->XilinxFreq;
	vt->Tc_1.Ti = vt->Tc_1.Ti/vt->XilinxFreq;

}

void svgen_set_time_keys_closed(SVGEN_PWM24 *vt)
{
	vt->Ta_0.Ti = VAR_FREQ_PWM_XTICS + 1;
	vt->Ta_1.Ti = 0;

	vt->Tb_0.Ti = VAR_FREQ_PWM_XTICS + 1;
	vt->Tb_1.Ti = 0;

	vt->Tc_0.Ti = VAR_FREQ_PWM_XTICS + 1;
	vt->Tc_1.Ti = 0;
}

void svgen_set_time_middle_keys_open(SVGEN_PWM24 *vt)
{
	vt->Ta_0.Ti = 0;
	vt->Ta_1.Ti = VAR_FREQ_PWM_XTICS + 1;

	vt->Tb_0.Ti = 0;
	vt->Tb_1.Ti = VAR_FREQ_PWM_XTICS + 1;

	vt->Tc_0.Ti = 0;
	vt->Tc_1.Ti = VAR_FREQ_PWM_XTICS + 1;
}